- inherited mcc ver 001.002 from vibryd mqx release. - use mu general int4 as the cpu2cpu int (num is 122 at a9 side). - add linux wait_event/wake_up mechanism on the buffer management of share memory - replace wait_event_interruptible### by wait_event###, so the sleep task wouldn't be waken up by reboot or CTRL+C signals. - use the offset address to do the MQX_TO_VIRT and VIRT_TO_MQX exchanges. - regmap_bits_updat can't write 1 to clear the bit-set asr, use regmap_read/write - fix mu irq clear hang issue only do the regmap once in the isr register func, and replace the multi-regmap operations in the kinds of mx6sx mcc related apis by one global imx_mu_reg. Signed-off-by: Richard Zhu <r65037@freescale.com>
54 lines
1.7 KiB
C
54 lines
1.7 KiB
C
/*
|
|
* Copyright (C) 2014 Freescale Semiconductor, Inc.
|
|
* Freescale IMX Linux-specific MCC implementation.
|
|
* Prototypes for Linunx-specific MCC library functions
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms and conditions of the GNU General Public License,
|
|
* version 2, as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
* more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with
|
|
* this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef __MCC_LINUX__
|
|
#define __MCC_LINUX__
|
|
|
|
/* Define the kinds of cache macros */
|
|
#define MCC_DCACHE_ENABLE(n)
|
|
#define MCC_DCACHE_DISABLE()
|
|
#define MCC_DCACHE_FLUSH()
|
|
#define MCC_DCACHE_FLUSH_LINE(p)
|
|
#define MCC_DCACHE_FLUSH_MLINES(p, m)
|
|
#define MCC_DCACHE_INVALIDATE()
|
|
#define MCC_DCACHE_INVALIDATE_LINE(p)
|
|
#define MCC_DCACHE_INVALIDATE_MLINES(p, m)
|
|
|
|
#define _mem_size unsigned int
|
|
|
|
void * virt_to_mqx(void *);
|
|
void * mqx_to_virt(void *);
|
|
#define VIRT_TO_MQX(x) virt_to_mqx(x)
|
|
#define MQX_TO_VIRT(x) mqx_to_virt(x)
|
|
|
|
/* Semaphore-related functions */
|
|
int mcc_init_semaphore(unsigned int);
|
|
int mcc_deinit_semaphore(unsigned int);
|
|
int mcc_get_semaphore(void);
|
|
int mcc_release_semaphore(void);
|
|
|
|
/* CPU-to-CPU interrupt-related functions */
|
|
int mcc_register_cpu_to_cpu_isr(void);
|
|
int mcc_generate_cpu_to_cpu_interrupt(void);
|
|
|
|
/* Memory management-related functions */
|
|
void mcc_memcpy(void *, void *, unsigned int);
|
|
void _mem_zero(void *, unsigned int);
|
|
|
|
#endif /* __MCC_LINUX__ */
|