summaryrefslogtreecommitdiff
path: root/ANDROID_3.4.5/arch/arm/mach-wmt/include/mach/wmt_i2c.h
diff options
context:
space:
mode:
Diffstat (limited to 'ANDROID_3.4.5/arch/arm/mach-wmt/include/mach/wmt_i2c.h')
-rwxr-xr-xANDROID_3.4.5/arch/arm/mach-wmt/include/mach/wmt_i2c.h403
1 files changed, 0 insertions, 403 deletions
diff --git a/ANDROID_3.4.5/arch/arm/mach-wmt/include/mach/wmt_i2c.h b/ANDROID_3.4.5/arch/arm/mach-wmt/include/mach/wmt_i2c.h
deleted file mode 100755
index 73f9c3e6..00000000
--- a/ANDROID_3.4.5/arch/arm/mach-wmt/include/mach/wmt_i2c.h
+++ /dev/null
@@ -1,403 +0,0 @@
-/*++
- linux/include/asm-arm/arch-wmt/wmt_i2c.h
-
- Copyright (c) 2008 WonderMedia Technologies, Inc.
-
- This program is free software: you can redistribute it and/or modify it under the
- terms of the GNU General Public License as published by the Free Software Foundation,
- either version 2 of the License, or (at your option) any later version.
-
- This program is distributed in the hope that 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/>.
-
- WonderMedia Technologies, Inc.
- 10F, 529, Chung-Cheng Road, Hsin-Tien, Taipei 231, R.O.C.
-
---*/
-/* Be sure that virtual mapping is defined right */
-
-#ifndef __ASM_ARCH_HARDWARE_H
-#error "You must include hardware.h, not wmt_i2c.h"
-#endif
-
-#ifndef _WMT_I2C_H_
-#define _WMT_I2C_H_
-/*-------------------- MODULE DEPENDENCY -------------------------------------*/
-
-#include "wmt_mmap.h"
-/*
- * Refer I2C 0.1 Module
- *
- */
-/*
- i2c api address
-
- Since i2c bus would probe all device which connect with it to add i2c adapter
- ,but we dont make sure which would connect with it. In order to reduce probe time
- ,we give a fake slave address for probing only.
- Be carefully, the i2c api address must be different from real device address
-*/
-
-#define WMT_I2C_API_I2C_ADDR 0x59 /*API address*/
-
-/*
- * Address
- */
-#define I2C_CR_ADDR (0x0000+I2C_BASE_ADDR)
-#define I2C_TCR_ADDR (0x0002+I2C_BASE_ADDR)
-#define I2C_CSR_ADDR (0x0004+I2C_BASE_ADDR)
-#define I2C_ISR_ADDR (0x0006+I2C_BASE_ADDR)
-#define I2C_IMR_ADDR (0x0008+I2C_BASE_ADDR)
-#define I2C_CDR_ADDR (0x000A+I2C_BASE_ADDR)
-#define I2C_TR_ADDR (0x000C+I2C_BASE_ADDR)
-#define I2C_DIV_ADDR (0x000E+I2C_BASE_ADDR)
-
-#define I2C1_CR_ADDR (0x0000+I2C1_BASE_ADDR)
-#define I2C1_TCR_ADDR (0x0002+I2C1_BASE_ADDR)
-#define I2C1_CSR_ADDR (0x0004+I2C1_BASE_ADDR)
-#define I2C1_ISR_ADDR (0x0006+I2C1_BASE_ADDR)
-#define I2C1_IMR_ADDR (0x0008+I2C1_BASE_ADDR)
-#define I2C1_CDR_ADDR (0x000A+I2C1_BASE_ADDR)
-#define I2C1_TR_ADDR (0x000C+I2C1_BASE_ADDR)
-#define I2C1_DIV_ADDR (0x000E+I2C1_BASE_ADDR)
-
-#define I2C2_CR_ADDR (0x0000+I2C2_BASE_ADDR)
-#define I2C2_TCR_ADDR (0x0002+I2C2_BASE_ADDR)
-#define I2C2_CSR_ADDR (0x0004+I2C2_BASE_ADDR)
-#define I2C2_ISR_ADDR (0x0006+I2C2_BASE_ADDR)
-#define I2C2_IMR_ADDR (0x0008+I2C2_BASE_ADDR)
-#define I2C2_CDR_ADDR (0x000A+I2C2_BASE_ADDR)
-#define I2C2_TR_ADDR (0x000C+I2C2_BASE_ADDR)
-#define I2C2_DIV_ADDR (0x000E+I2C2_BASE_ADDR)
-
-#define I2C3_CR_ADDR (0x0000+I2C3_BASE_ADDR)
-#define I2C3_TCR_ADDR (0x0002+I2C3_BASE_ADDR)
-#define I2C3_CSR_ADDR (0x0004+I2C3_BASE_ADDR)
-#define I2C3_ISR_ADDR (0x0006+I2C3_BASE_ADDR)
-#define I2C3_IMR_ADDR (0x0008+I2C3_BASE_ADDR)
-#define I2C3_CDR_ADDR (0x000A+I2C3_BASE_ADDR)
-#define I2C3_TR_ADDR (0x000C+I2C3_BASE_ADDR)
-#define I2C3_DIV_ADDR (0x000E+I2C3_BASE_ADDR)
-
-#define I2C4_CR_ADDR (0x0000+I2C4_BASE_ADDR)
-#define I2C4_TCR_ADDR (0x0002+I2C4_BASE_ADDR)
-#define I2C4_CSR_ADDR (0x0004+I2C4_BASE_ADDR)
-#define I2C4_ISR_ADDR (0x0006+I2C4_BASE_ADDR)
-#define I2C4_IMR_ADDR (0x0008+I2C4_BASE_ADDR)
-#define I2C4_CDR_ADDR (0x000A+I2C4_BASE_ADDR)
-#define I2C4_TR_ADDR (0x000C+I2C4_BASE_ADDR)
-#define I2C4_DIV_ADDR (0x000E+I2C4_BASE_ADDR)
-
-/* Slave Address*/
-#define I2C_SCR_ADDR (0x0010+I2C_BASE_ADDR)
-#define I2C_SSR_ADDR (0x0012+I2C_BASE_ADDR)
-#define I2C_SISR_ADDR (0x0014+I2C_BASE_ADDR)
-#define I2C_SIMR_ADDR (0x0016+I2C_BASE_ADDR)
-#define I2C_SDR_ADDR (0x0018+I2C_BASE_ADDR)
-#define I2C_STR_ADDR (0x001A+I2C_BASE_ADDR)
-
-/*
- * Registers
- */
-#define I2C_CR_REG REG16_PTR(0x0000+I2C_BASE_ADDR)
-#define I2C_TCR_REG REG16_PTR(0x0002+I2C_BASE_ADDR)
-#define I2C_CSR_REG REG16_PTR(0x0004+I2C_BASE_ADDR)
-#define I2C_ISR_REG REG16_PTR(0x0006+I2C_BASE_ADDR)
-#define I2C_IMR_REG REG16_PTR(0x0008+I2C_BASE_ADDR)
-#define I2C_CDR_REG REG16_PTR(0x000A+I2C_BASE_ADDR)
-#define I2C_TR_REG REG16_PTR(0x000C+I2C_BASE_ADDR)
-#define I2C_DIV_REG REG16_PTR(0x000E+I2C_BASE_ADDR)
-
-#define I2C1_CR_REG REG16_PTR(0x0000+I2C1_BASE_ADDR)
-#define I2C1_TCR_REG REG16_PTR(0x0002+I2C1_BASE_ADDR)
-#define I2C1_CSR_REG REG16_PTR(0x0004+I2C1_BASE_ADDR)
-#define I2C1_ISR_REG REG16_PTR(0x0006+I2C1_BASE_ADDR)
-#define I2C1_IMR_REG REG16_PTR(0x0008+I2C1_BASE_ADDR)
-#define I2C1_CDR_REG REG16_PTR(0x000A+I2C1_BASE_ADDR)
-#define I2C1_TR_REG REG16_PTR(0x000C+I2C1_BASE_ADDR)
-#define I2C1_DIV_REG REG16_PTR(0x000E+I2C1_BASE_ADDR)
-
-#define I2C2_CR_REG REG16_PTR(0x0000+I2C2_BASE_ADDR)
-#define I2C2_TCR_REG REG16_PTR(0x0002+I2C2_BASE_ADDR)
-#define I2C2_CSR_REG REG16_PTR(0x0004+I2C2_BASE_ADDR)
-#define I2C2_ISR_REG REG16_PTR(0x0006+I2C2_BASE_ADDR)
-#define I2C2_IMR_REG REG16_PTR(0x0008+I2C2_BASE_ADDR)
-#define I2C2_CDR_REG REG16_PTR(0x000A+I2C2_BASE_ADDR)
-#define I2C2_TR_REG REG16_PTR(0x000C+I2C2_BASE_ADDR)
-#define I2C2_DIV_REG REG16_PTR(0x000E+I2C2_BASE_ADDR)
-
-#define I2C3_CR_REG REG16_PTR(0x0000+I2C3_BASE_ADDR)
-#define I2C3_TCR_REG REG16_PTR(0x0002+I2C3_BASE_ADDR)
-#define I2C3_CSR_REG REG16_PTR(0x0004+I2C3_BASE_ADDR)
-#define I2C3_ISR_REG REG16_PTR(0x0006+I2C3_BASE_ADDR)
-#define I2C3_IMR_REG REG16_PTR(0x0008+I2C3_BASE_ADDR)
-#define I2C3_CDR_REG REG16_PTR(0x000A+I2C3_BASE_ADDR)
-#define I2C3_TR_REG REG16_PTR(0x000C+I2C3_BASE_ADDR)
-#define I2C3_DIV_REG REG16_PTR(0x000E+I2C3_BASE_ADDR)
-
-#define I2C4_CR_REG REG16_PTR(0x0000+I2C4_BASE_ADDR)
-#define I2C4_TCR_REG REG16_PTR(0x0002+I2C4_BASE_ADDR)
-#define I2C4_CSR_REG REG16_PTR(0x0004+I2C4_BASE_ADDR)
-#define I2C4_ISR_REG REG16_PTR(0x0006+I2C4_BASE_ADDR)
-#define I2C4_IMR_REG REG16_PTR(0x0008+I2C4_BASE_ADDR)
-#define I2C4_CDR_REG REG16_PTR(0x000A+I2C4_BASE_ADDR)
-#define I2C4_TR_REG REG16_PTR(0x000C+I2C4_BASE_ADDR)
-#define I2C4_DIV_REG REG16_PTR(0x000E+I2C4_BASE_ADDR)
-
-/* Slave Registers*/
-#define I2C_SCR_REG REG16_PTR(0x0010+I2C_BASE_ADDR)
-#define I2C_SSR_REG REG16_PTR(0x0012+I2C_BASE_ADDR)
-#define I2C_SISR_REG REG16_PTR(0x0014+I2C_BASE_ADDR)
-#define I2C_SIMR_REG REG16_PTR(0x0016+I2C_BASE_ADDR)
-#define I2C_SDR_REG REG16_PTR(0x0018+I2C_BASE_ADDR)
-#define I2C_STR_REG REG16_PTR(0x001A+I2C_BASE_ADDR)
-
-/*
- * Val Registers
- */
-#define I2C_CR_VAL REG16_VAL(0x0000+I2C_BASE_ADDR)
-#define I2C_TCR_VAL REG16_VAL(0x0002+I2C_BASE_ADDR)
-#define I2C_CSR_VAL REG16_VAL(0x0004+I2C_BASE_ADDR)
-#define I2C_ISR_VAL REG16_VAL(0x0006+I2C_BASE_ADDR)
-#define I2C_IMR_VAL REG16_VAL(0x0008+I2C_BASE_ADDR)
-#define I2C_CDR_VAL REG16_VAL(0x000A+I2C_BASE_ADDR)
-#define I2C_TR_VAL REG16_VAL(0x000C+I2C_BASE_ADDR)
-#define I2C_DIV_VAL REG16_VAL(0x000E+I2C_BASE_ADDR)
-
-#define I2C1_CR_VAL REG16_VAL(0x0000+I2C1_BASE_ADDR)
-#define I2C1_TCR_VAL REG16_VAL(0x0002+I2C1_BASE_ADDR)
-#define I2C1_CSR_VAL REG16_VAL(0x0004+I2C1_BASE_ADDR)
-#define I2C1_ISR_VAL REG16_VAL(0x0006+I2C1_BASE_ADDR)
-#define I2C1_IMR_VAL REG16_VAL(0x0008+I2C1_BASE_ADDR)
-#define I2C1_CDR_VAL REG16_VAL(0x000A+I2C1_BASE_ADDR)
-#define I2C1_TR_VAL REG16_VAL(0x000C+I2C1_BASE_ADDR)
-#define I2C1_DIV_VAL REG16_VAL(0x000E+I2C1_BASE_ADDR)
-
-#define I2C2_CR_VAL REG16_VAL(0x0000+I2C2_BASE_ADDR)
-#define I2C2_TCR_VAL REG16_VAL(0x0002+I2C2_BASE_ADDR)
-#define I2C2_CSR_VAL REG16_VAL(0x0004+I2C2_BASE_ADDR)
-#define I2C2_ISR_VAL REG16_VAL(0x0006+I2C2_BASE_ADDR)
-#define I2C2_IMR_VAL REG16_VAL(0x0008+I2C2_BASE_ADDR)
-#define I2C2_CDR_VAL REG16_VAL(0x000A+I2C2_BASE_ADDR)
-#define I2C2_TR_VAL REG16_VAL(0x000C+I2C2_BASE_ADDR)
-#define I2C2_DIV_VAL REG16_VAL(0x000E+I2C2_BASE_ADDR)
-
-#define I2C3_CR_VAL REG16_VAL(0x0000+I2C3_BASE_ADDR)
-#define I2C3_TCR_VAL REG16_VAL(0x0002+I2C3_BASE_ADDR)
-#define I2C3_CSR_VAL REG16_VAL(0x0004+I2C3_BASE_ADDR)
-#define I2C3_ISR_VAL REG16_VAL(0x0006+I2C3_BASE_ADDR)
-#define I2C3_IMR_VAL REG16_VAL(0x0008+I2C3_BASE_ADDR)
-#define I2C3_CDR_VAL REG16_VAL(0x000A+I2C3_BASE_ADDR)
-#define I2C3_TR_VAL REG16_VAL(0x000C+I2C3_BASE_ADDR)
-#define I2C3_DIV_VAL REG16_VAL(0x000E+I2C3_BASE_ADDR)
-
-#define I2C4_CR_VAL REG16_VAL(0x0000+I2C4_BASE_ADDR)
-#define I2C4_TCR_VAL REG16_VAL(0x0002+I2C4_BASE_ADDR)
-#define I2C4_CSR_VAL REG16_VAL(0x0004+I2C4_BASE_ADDR)
-#define I2C4_ISR_VAL REG16_VAL(0x0006+I2C4_BASE_ADDR)
-#define I2C4_IMR_VAL REG16_VAL(0x0008+I2C4_BASE_ADDR)
-#define I2C4_CDR_VAL REG16_VAL(0x000A+I2C4_BASE_ADDR)
-#define I2C4_TR_VAL REG16_VAL(0x000C+I2C4_BASE_ADDR)
-#define I2C4_DIV_VAL REG16_VAL(0x000E+I2C4_BASE_ADDR)
-
-/* Slave Val Registers*/
-#define I2C_SCR_VAL REG16_VAL(0x0010+I2C_BASE_ADDR)
-#define I2C_SSR_VAL REG16_VAL(0x0012+I2C_BASE_ADDR)
-#define I2C_SISR_VAL REG16_VAL(0x0014+I2C_BASE_ADDR)
-#define I2C_SIMR_VAL REG16_VAL(0x0016+I2C_BASE_ADDR)
-#define I2C_SDR_VAL REG16_VAL(0x0018+I2C_BASE_ADDR)
-#define I2C_STR_VAL REG16_VAL(0x001A+I2C_BASE_ADDR)
-
-/*
- * I2C_CR_REG
- * I2C Controller Control
- */
-/* Reserved [15:05] */
-/* [04:04] -- PCLK_SLE tied to Zero */
-#define I2C_CR_CPU_RDY 0x0008
-#define I2C_CR_TX_END 0x0004
-#define I2C_CR_TX_NEXT_NO_ACK 0x0002
-#define I2C_CR_TX_NEXT_ACK 0x0000
-#define I2C_CR_ENABLE 0x0001
-#define I2C_SLAV_MODE_SEL 0x8000
-/*
- * I2C_TCR_REG
- * I2C Transfer Control
- *
- */
-#define I2C_TCR_HS_MODE 0x2000 /* [13:13] */
-#define I2C_TCR_STANDARD_MODE 0x0000 /* [15:15] */
-#define I2C_TCR_FAST_MODE 0x8000
-#define I2C_TCR_MASTER_WRITE 0x0000 /* [14:14] */
-#define I2C_TCR_MASTER_READ 0x4000
-/* Reserved [13:07] */
-#define I2C_TCR_SLAVE_ADDR_MASK 0x007F /* [06:00] */
-
-/*
- * I2C_CSR_REG
- * I2C Status
- *
- */
-/* Reserved [15:02] */
-#define I2C_READY 0x0002 /* [01:01] R */
-#define I2C_BUSY 0x0000
-#define I2C_STATUS_MASK 0x0002
-#define I2C_CSR_RCV_ACK 0x0000 /* [00:00] R */
-#define I2C_CSR_RCV_NOT_ACK 0x0001
-#define I2C_CSR_RCV_ACK_MASK 0x0001
-
-/*
- * I2C_ISR_REG
- * I2C Interrupt Status
- *
- */
-/* Reserved [15:03] */
-#define I2C_ISR_SCL_TIME_OUT 0x0004 /* [02:02] R */
-#define I2C_ISR_SCL_TIME_OUT_WRITE_CLEAR 0x0004
-#define I2C_ISR_BYTE_END 0x0002 /* [01:01] R */
-#define I2C_ISR_BYTE_END_WRITE_CLEAR 0x0002
-#define I2C_ISR_NACK_ADDR 0x0001 /* [00:00] R */
-#define I2C_ISR_NACK_ADDR_WRITE_CLEAR 0x0001
-
-#define I2C_ISR_ALL_WRITE_CLEAR 0x0007
-/*
- * I2C_IMR_REG
- * I2C Interrupt Mask
- *
- */
-/* Reserved [15:03] */
-#define I2C_IMR_SCL_TIME_OUT_MASK 0x0004 /* [02:02] */
-#define I2C_IMR_BYTE_END_MASK 0x0002 /* [01:01] */
-#define I2C_IMR_NACK_ADDR_MASK 0x0001 /* [00:00] */
-
-#define I2C_IMR_ALL_ENABLE 0x0007
-/*
- * I2C_CDR_REG
- * I2C Data IO
- *
- */
-#define I2C_CDR_DATA_READ_MASK 0xFF00 /* [15:08] */
-#define I2C_CDR_DATA_WRITE_MASK 0x00FF /* [07:00] */
-
-
-/*
- * I2C_TR_REG
- * I2C Timer Parameters
- *
- */
-#define I2C_TR_SCL_TIME_OUT_MASK 0xFF00 /* [15:08] */
-#define I2C_TR_FSTP_MASK 0x00FF /* [07:00] */
-
-#define I2C_TR_STD_VALUE 0xFF64 /* standard mode*/
-#define I2C_TR_FAST_VALUE 0xFF19 /* fast mode*/
-
-
-/*
- * I2C_DIV_REG
- * I2C DIV
- *
- */
-#define APB_96M_I2C_DIV 7 /*Dean revised 2007/9/11 */
-#define APB_166M_I2C_DIV 12 /*Dean revised 2008/5/9 */
-
-
-
-/*
- * I2C slave registers setting
- *
- */
-#define HS_MASTER_CODE 0x0800
-
-#define I2C_SLAVE_ADDR 0x59
-#define I2C_SLAVE_MASK 0x007F
-#define I2C_SLAVE_NACK BIT12
-#define I2C_SLAVE_HS_MODE BIT14
-#define I2C_SLAVE_EN BIT15
-
-#define I2C_SISR_SCL_TIME_OUT 0x0004 /* [02:02] R */
-#define I2C_SISR_SCL_TIME_OUT_WRITE_CLEAR 0x0004
-#define I2C_SISR_BYTE_END 0x0002 /* [01:01] R */
-#define I2C_SISR_BYTE_END_WRITE_CLEAR 0x0002
-#define I2C_SISR_DAT_REQ 0x0001 /* [00:00] R */
-#define I2C_SISR_DAT_REQ_WRITE_CLEAR 0x0001
-
-#define I2C_SISR_ALL_WRITE_CLEAR 0x0007
-
-#define I2C_SIMR_SCL_TIME_OUT_MASK 0x0004 /* [02:02] */
-#define I2C_SIMR_BYTE_END_MASK 0x0002 /* [01:01] */
-#define I2C_SIMR_NACK_ADDR_MASK 0x0001 /* [00:00] */
-
-#define I2C_SIMR_ALL_ENABLE 0x0007
-
-#define I2C_SRCV_NACK BIT0
-#define I2C_SREAD BIT1
-#define I2C_SACT BIT2
-
-#define I2C_SLAVE_WRITE_DATA_SHIFT 0
-#define I2C_SLAVE_READ_DATA_SHIFT 8
-#define I2C_SLAVE_READ_DATA_MASK 0xFF00
-#define I2C_SLAVE_WRITE_DATA_MASK 0x00FF
-
-enum i2c_mode_e {
- I2C_STANDARD_MODE = 0 ,
- I2C_FAST_MODE = 1,
- I2C_HS_MODE = 2,
-};
-
-struct i2c_regs_s {
- volatile unsigned short cr_reg; /* IIC controller control register*/
- volatile unsigned short tcr_reg; /* IIC controller transfer control register*/
- volatile unsigned short csr_reg; /* IIC controller status register*/
- volatile unsigned short isr_reg; /* IIC controller interrupt status register*/
- volatile unsigned short imr_reg; /* IIC controller interrupt mask register*/
- volatile unsigned short cdr_reg; /* IIC controller data I/O buffer register*/
- volatile unsigned short tr_reg; /* IIC controller time parameter register*/
- volatile unsigned short div_reg; /* IIC controller clock divider register*/
- volatile unsigned short scr_reg; /* IIC slave controller control register*/
- volatile unsigned short cssr_reg; /* IIC slave controller status register*/
- volatile unsigned short sisr_reg; /* IIC slave controller interrupt status register*/
- volatile unsigned short simr_reg; /* IIC slave controller interrupt mask register*/
- volatile unsigned short csdr_reg; /* IIC slave controller data I/O buffer register*/
- volatile unsigned short str_reg; /* IIC slave controller time parameter register*/
-};
-
-#define SUSPEND_NOTIFY 0
-#define SUSPEND_SAVE_STATE 1
-#define SUSPEND_DISABLE 2
-#define SUSPEND_POWER_DOWN 3
-#define RESUME_POWER_ON 0
-#define RESUME_RESTORE_STATE 1
-#define RESUME_ENABLE 2
-
-#define I2C_ALGO_WMT 0x00900000 /* via WMT on-chip i2c algo*/
-
-#define I2C_ADAPTER_RETRIES 3
-#define I2C_ALGO_UDELAY 10
-#define I2C_ALGO_TIMEOUT 500
-
-#define MAX_MESSAGES 65536 /* maximum number of messages to send*/
-
-
-#define I2C_SET_STANDARD_MODE 0x07A0
-#define I2C_SET_FAST_MODE 0x07A1
-
-#if 0
-struct i2c_algo_wmt_data {
- int (*write_msg)(unsigned int slave_addr, char *buf, unsigned int length , int restart, int last) ;
- int (*read_msg)(unsigned int slave_addr, char *buf, unsigned int length , int restart, int last) ;
- int (*send_request)(struct i2c_msg *msg, int msg_num, int non_block);
-#ifdef CONFIG_SND_SOC_VT1603
- int (*vt1603_write_for_read)(unsigned int slave_addr, char *buf, unsigned int length , int restart, int last);
-#endif
- int (*wait_bus_not_busy) (void);
- void (*reset) (void);
- void (*set_mode)(enum i2c_mode_e) ;
- int udelay;
- int timeout;
-};
-#endif
-
-#endif