⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 plf_io.h

📁 开放源码实时操作系统源码.
💻 H
📖 第 1 页 / 共 2 页
字号:

#define KS32C_IOPCON_DRQ0_shift     20
#define KS32C_IOPCON_DRQ1_shift     23

#define KS32C_IOPCON_DAK_MASK       0x03
#define KS32C_IOPCON_DAK_AKTIV_LOW  0x00
#define KS32C_IOPCON_DAK_AKTIV_HI   0x01
#define KS32C_IOPCON_DAK_ENABLE     0x02

#define KS32C_IOPCON_DAK0_shift     26
#define KS32C_IOPCON_DAK1_shift     28

#define KS32C_IOPCON_TOEN_ENABLE    0x01

#define KS32C_IOPCON_TO0_shift      30
#define KS32C_IOPCON_TO1_shift      31

#define KS32C_IOPDATA               (KS32C_REG_BASE + 0x5008)

#define KS32C_IOPDATA_P0            (1<<0)
#define KS32C_IOPDATA_P1            (1<<1)
#define KS32C_IOPDATA_P2            (1<<2)
#define KS32C_IOPDATA_P3            (1<<3)
#define KS32C_IOPDATA_P4            (1<<4)
#define KS32C_IOPDATA_P5            (1<<5)
#define KS32C_IOPDATA_P6            (1<<6)
#define KS32C_IOPDATA_P7            (1<<7)
#define KS32C_IOPDATA_P8_XIRQ0      (1<<8)
#define KS32C_IOPDATA_P9_XIRQ1      (1<<9)
#define KS32C_IOPDATA_P10_XIRQ2     (1<<10)
#define KS32C_IOPDATA_P11_XIRQ3     (1<<11)
#define KS32C_IOPDATA_P12_DRQ0      (1<<12)
#define KS32C_IOPDATA_P13_DRQ1      (1<<13)
#define KS32C_IOPDATA_P14_DAK0      (1<<14)
#define KS32C_IOPDATA_P15_DAK1      (1<<15)
#define KS32C_IOPDATA_P16_TO0       (1<<16)
#define KS32C_IOPDATA_P17_TO1       (1<<17)

//-----------------------------------------------------------------------------
// Timers

#define KS32C_TMOD                  (KS32C_REG_BASE + 0x6000)
#define KS32C_TDATA0                (KS32C_REG_BASE + 0x6004)
#define KS32C_TDATA1                (KS32C_REG_BASE + 0x6008)
#define KS32C_TCNT0                 (KS32C_REG_BASE + 0x600c)
#define KS32C_TCNT1                 (KS32C_REG_BASE + 0x6010)

#define KS32C_TMOD_TE0              0x00000001
#define KS32C_TMOD_TMD0             0x00000002
#define KS32C_TMOD_TCLR0            0x00000004
#define KS32C_TMOD_TE1              0x00000008
#define KS32C_TMOD_TMD1             0x00000010
#define KS32C_TMOD_TCLR1            0x00000020


//-----------------------------------------------------------------------------
// UART

#define KS32C_UART0_BASE            (KS32C_REG_BASE + 0xd000)
#define KS32C_UART1_BASE            (KS32C_REG_BASE + 0xe000)

#define KS32C_UART_LCON             0x0000
#define KS32C_UART_CON              0x0004
#define KS32C_UART_STAT             0x0008
#define KS32C_UART_TXBUF            0x000c
#define KS32C_UART_RXBUF            0x0010
#define KS32C_UART_BRDIV            0x0014
#define KS32C_UART_BRDCNT           0x0018
#define KS32C_UART_BRDCLK           0x001c

#define KS32C_UART_LCON_5_DBITS     0x00
#define KS32C_UART_LCON_6_DBITS     0x01
#define KS32C_UART_LCON_7_DBITS     0x02
#define KS32C_UART_LCON_8_DBITS     0x03
#define KS32C_UART_LCON_1_SBITS     0x00
#define KS32C_UART_LCON_2_SBITS     0x04
#define KS32C_UART_LCON_NO_PARITY   0x00
#define KS32C_UART_LCON_EVEN_PARITY 0x00
#define KS32C_UART_LCON_ODD_PARITY  0x28
#define KS32C_UART_LCON_1_PARITY    0x30
#define KS32C_UART_LCON_0_PARITY    0x38
#define KS32C_UART_LCON_SCS         0x40
#define KS32C_UART_LCON_IR          0x80

#define KS32C_UART_CON_RXM_MASK     0x03
#define KS32C_UART_CON_RXM_INT      0x01
#define KS32C_UART_CON_TXM_MASK     0x0c
#define KS32C_UART_CON_TXM_INT      0x08
#define KS32C_UART_CON_RX_ERR_INT   0x04


#define KS32C_UART_STAT_DTR         0x10
#define KS32C_UART_STAT_RDR         0x20
#define KS32C_UART_STAT_TXE         0x40  // tx empty
#define KS32C_UART_STAT_TC          0x80  // tx complete

//-----------------------------------------------------------------------------
// Cache
#define KS32C_CACHE_SET0_ADDR       0x10000000
#define KS32C_CACHE_SET1_ADDR       0x10800000
#define KS32C_CACHE_TAG_ADDR        0x11000000

//-----------------------------------------------------------------------------
// GDMA
#define KS32C_GDMA_CON0             (KS32C_REG_BASE + 0xb000)
#define KS32C_GDMA_SRC0             (KS32C_REG_BASE + 0xb004)
#define KS32C_GDMA_DST0             (KS32C_REG_BASE + 0xb008)
#define KS32C_GDMA_CNT0             (KS32C_REG_BASE + 0xb00c)
#define KS32C_GDMA_CON1             (KS32C_REG_BASE + 0xc000)
#define KS32C_GDMA_SRC1             (KS32C_REG_BASE + 0xc004)
#define KS32C_GDMA_DST1             (KS32C_REG_BASE + 0xc008)
#define KS32C_GDMA_CNT1             (KS32C_REG_BASE + 0xc00c)

//-----------------------------------------------------------------------------
// I2C
#define KS32C_I2CCON                (KS32C_REG_BASE + 0xf000)
#define KS32C_I2C_CON_BF            (1<<0)
#define KS32C_I2C_CON_IEN           (1<<1)
#define KS32C_I2C_CON_LRB           (1<<2)
#define KS32C_I2C_CON_ACK           (1<<3)
#define KS32C_I2C_CON_START         (1<<4)
#define KS32C_I2C_CON_STOP          (2<<4)
#define KS32C_I2C_CON_RESTART       (3<<4)
#define KS32C_I2C_CON_BUSY          (1<<6)
#define KS32C_I2C_CON_RESET         (1<<7)
#define KS32C_I2CBUF                (KS32C_REG_BASE +0xf004)
#define KS32C_I2CPS                 (KS32C_REG_BASE +0xf008)

#define KS32C_I2C_FREQ(freq)        ((CYGNUM_HAL_CPUCLOCK/(freq) - 3)/16)
#define KS32C_I2C_RD                (0x01)
#define KS32C_I2C_WR                (0x00)

#ifndef __ASSEMBLER__
typedef struct hal_ks32c_i2c_msg_s
{
    cyg_uint8   devaddr;
    cyg_int8    status;
    cyg_uint8*  pbuf;
    cyg_uint32  bufsize;
} hal_ks32c_i2c_msg_t;

//  Transfer the I2C messages.
externC int
hal_ks32c_i2c_transfer(cyg_uint32 nmsg, hal_ks32c_i2c_msg_t* pmsgs);
#endif

//-----------------------------------------------------------------------------
// Memory map is 1-1

#define CYGARC_PHYSICAL_ADDRESS(_x_) (_x_)

//-----------------------------------------------------------------------------
// AIM 711 specific

// Mamory maping
#define AIM711_ROM0_LA_START    0x02000000
#define AIM711_ROM0_LA_END      0x02200000
#define AIM711_DRAM_LA_START    0x00000000
#define AIM711_DRAM_LA_END      0x00800000
#define AIM711_EXT0_LA_START    0x03fd0000
#define AIM711_EXT0_LA_END      0x03fd4000
#define AIM711_EXT1_LA_START    0x03fd4000
#define AIM711_EXT1_LA_END      0x03fd8000
#define AIM711_EXT2_LA_START    0x03fd8000
#define AIM711_EXT2_LA_END      0x03fdc000
#define AIM711_EXT3_LA_START    0x03fdc000
#define AIM711_EXT3_LA_END      0x03fc0000

#define AIM711_COM0_DEBUG_BASE  KS32C_UART0_BASE
#define AIM711_COM1_BASE        (AIM711_EXT0_LA_START|0x04000000 + 8)
#define AIM711_COM2_BASE        KS32C_UART1_BASE
#define AIM711_EXTBUS_BASE      (AIM711_EXT2_LA_START|0x04000000)

// I2C address of RTC (wallclock)
#define AIM711_RTC_ADDR        0xd0

// I2C address and size of EEPROM
#define AIM711_EEPROM_ADDR     0xa0
#define AIM711_EEPROM_SIZE     256
#define AIM711_EEPROM_PAGESIZE 8

// Interrupt vectors with AIM 711 naming
#define AIM711_INTERRUPT_COM1    CYGNUM_HAL_INTERRUPT_EXT0
#define AIM711_INTERRUPT_RTC     CYGNUM_HAL_INTERRUPT_EXT1
#define AIM711_INTERRUPT_IRQ0    CYGNUM_HAL_INTERRUPT_EXT2
#define AIM711_INTERRUPT_IRQ1    CYGNUM_HAL_INTERRUPT_EXT3

// GPIO bits with AIM 711 naming
#define AIM711_GPIO_LED0         KS32C_IOPDATA_P0
#define AIM711_GPIO_LED1         KS32C_IOPDATA_P1
#define AIM711_GPIO_LED2         KS32C_IOPDATA_P2
#define AIM711_GPIO_RESET        KS32C_IOPDATA_P3
#define AIM711_GPIO_POWERLED     KS32C_IOPDATA_P4
#define AIM711_GPIO_UARTIRQ      KS32C_IOPDATA_P8_XIRQ0
#define AIM711_GPIO_RTCIRQ       KS32C_IOPDATA_P9_XIRQ1
#define AIM711_GPIO_DIN0_DRQ0    KS32C_IOPDATA_P12_DRQ0
#define AIM711_GPIO_DIN1_DRQ1    KS32C_IOPDATA_P13_DRQ1
#define AIM711_GPIO_DIN2_IRQ0    KS32C_IOPDATA_P10_XIRQ2
#define AIM711_GPIO_DIN3_IRQ1    KS32C_IOPDATA_P11_XIRQ3
#define AIM711_GPIO_DOUT0_DAK0   KS32C_IOPDATA_P14_DAK0
#define AIM711_GPIO_DOUT1_DAK1   KS32C_IOPDATA_P15_DAK1
#define AIM711_GPIO_DOUT2_TO0    KS32C_IOPDATA_P16_TO0
#define AIM711_GPIO_DOUT3_TO1    KS32C_IOPDATA_P17_TO1

// Macros for usage of GPIO
#define AIM711_GPIO(_which_,_value_) \
do { \
    cyg_uint32 val; \
    HAL_READ_UINT32(KS32C_IOPDATA, val); \
    val &= ~(_which_); \
    val |= (_which_)&(_value_); \
    HAL_WRITE_UINT32(KS32C_IOPDATA, val); \
} while (0)

#define AIM711_GPIO_SET(_x_) \
do { \
    cyg_uint32 val; \
    HAL_READ_UINT32(KS32C_IOPDATA, val); \
    val |= (_x_); \
    HAL_WRITE_UINT32(KS32C_IOPDATA, val); \
} while (0)

#define AIM711_GPIO_CLR(_x_) \
do { \
    cyg_uint32 val; \
    HAL_READ_UINT32(KS32C_IOPDATA, val); \
    val &= ~(_x_); \
    HAL_WRITE_UINT32(KS32C_IOPDATA, val); \
} while (0)

#define AIM711_GPIO_GET(_x_) \
do { \
    cyg_uint32 _val; \
    HAL_READ_UINT32(KS32C_IOPDATA, _val); \
    (_x_) = _val; \
} while (0)

//-----------------------------------------------------------------------------
// AIM 711 specific EEPROM support

#ifndef __ASSEMBLER__
externC int
hal_aim711_eeprom_read(cyg_uint8 *buf, int offset, int len);

externC int
hal_aim711_eeprom_write(cyg_uint8 *buf, int offset, int len);
#endif

//-----------------------------------------------------------------------------
// end of plf_io.h
#endif // CYGONCE_HAL_PLF_IO_H

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -