1
0
mirror of https://github.com/physwizz/a155-U-u1.git synced 2025-10-18 01:15:33 +00:00
Files
physwizz 99537be4e2 first
2024-03-11 06:53:12 +11:00

94 lines
2.6 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (C) 2015 MediaTek Inc.
*/
#ifndef __CCIF_HIF_PLATFORM_H__
#define __CCIF_HIF_PLATFORM_H__
#include <linux/io.h>
#define ccif_write16(b, a, v) \
do {\
writew(v, (b) + (a));\
mb(); /* make sure register access in order */ \
} while (0)
#define ccif_write8(b, a, v) \
do {\
writeb(v, (b) + (a));\
mb(); /* make sure register access in order */ \
} while (0)
#define ccif_read16(b, a) ioread16((void __iomem *)((b)+(a)))
#define ccif_read8(b, a) ioread8((void __iomem *)((b)+(a)))
int ccif_read32(void *b, unsigned long a);
void ccif_write32(void *b, unsigned long a, unsigned int v);
/*CCIF */
#define APCCIF_CON (0x00)
#define APCCIF_BUSY (0x04)
#define APCCIF_START (0x08)
#define APCCIF_TCHNUM (0x0C)
#define APCCIF_RCHNUM (0x10)
#define APCCIF_ACK (0x14)
#define APCCIF_IRQ0_MASK (0x20)
#define APCCIF_IRQ1_MASK (0x24)
#define APCCIF_CHDATA (0x100)
#define RINGQ_BASE (0)
#define RINGQ_SRAM (15)
#define RINGQ_EXP_BASE (15)
#define CCIF_CH_NUM 24
#define AP_MD_CCB_WAKEUP (7)
/*AP to MD*/
#define H2D_EXCEPTION_ACK (RINGQ_EXP_BASE+1)
#define H2D_EXCEPTION_CLEARQ_ACK (RINGQ_EXP_BASE+2)
#define H2D_FORCE_MD_ASSERT (RINGQ_EXP_BASE+3)
#define H2D_MPU_FORCE_ASSERT (RINGQ_EXP_BASE+4)
#define H2D_SRAM (RINGQ_SRAM)
#define H2D_RINGQ0 (RINGQ_BASE+0)
#define H2D_RINGQ1 (RINGQ_BASE+1)
#define H2D_RINGQ2 (RINGQ_BASE+2)
#define H2D_RINGQ3 (RINGQ_BASE+3)
#define H2D_RINGQ4 (RINGQ_BASE+4)
#define H2D_RINGQ5 (RINGQ_BASE+5)
#define H2D_RINGQ6 (RINGQ_BASE+6)
#define H2D_RINGQ7 (RINGQ_BASE+7)
/*MD to AP*/
#define CCIF_HW_CH_RX_RESERVED \
((1 << (RINGQ_EXP_BASE+0)) | (1 << (RINGQ_EXP_BASE+5)))
#define D2H_EXCEPTION_INIT (RINGQ_EXP_BASE+1)
#define D2H_EXCEPTION_INIT_DONE (RINGQ_EXP_BASE+2)
#define D2H_EXCEPTION_CLEARQ_DONE (RINGQ_EXP_BASE+3)
#define D2H_EXCEPTION_ALLQ_RESET (RINGQ_EXP_BASE+4)
#define AP_MD_PEER_WAKEUP (RINGQ_EXP_BASE+5)
#define AP_MD_SEQ_ERROR (RINGQ_EXP_BASE+6)
#define AP_MD_DATA_NOTIFY (RINGQ_EXP_BASE+8)
#define D2H_SRAM (RINGQ_SRAM)
#define D2H_RINGQ0 (RINGQ_BASE+0)
#define D2H_RINGQ1 (RINGQ_BASE+1)
#define D2H_RINGQ2 (RINGQ_BASE+2)
#define D2H_RINGQ3 (RINGQ_BASE+3)
#define D2H_RINGQ4 (RINGQ_BASE+4)
#define D2H_RINGQ5 (RINGQ_BASE+5)
#define D2H_RINGQ6 (RINGQ_BASE+6)
#define D2H_RINGQ7 (RINGQ_BASE+7)
#define CCIF_SRAM_SIZE 512
/* use hw_channel = usr_id + AP_MD_DATA_NOTIFY */
enum ccif_isr_cb_user_id {
ID_CCIF_USER_DATA = 0,
ID_CCIF_CB_MAX,
};
#endif /*__CCIF_HIF_PLATFORM_H__*/