亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? i2chip_hw.h

?? 最新版FreeRTOS, 包擴多種開發平臺的移植
?? H
字號:
/*
********************************************************************************
* TERN, Inc.
* (c) Copyright 2005, http://www.tern.com
*
* - Created to support i2chip module on a variety of TERN hardware platforms.
********************************************************************************
*/

#ifndef _I2CHIP_HW_H_
#define _I2CHIP_HW_H_

#include "types.h"

#ifdef TERN_SC    // SensorCore controller, has mapping identical to the RL
#define TERN_RL
#endif

#ifdef TERN_RL    // R-Engine-L controller, with mapping at MCS0.
#define I2CHIP_MCS_DIRECT
#define I2CHIP_INT4
#define TERN_RE
#endif                // TERN_RL

#ifdef TERN_5E
#define TERN_586
#endif

#ifdef TERN_RD
#define TERN_RE
#endif                // TERN_RD

#ifdef TERN_RE
#define TERN_186
#endif

#ifdef TERN_P51
void p51_window(unsigned int page);
#define I2CHIP_WINDOW
#define I2CHIP_P51
#ifdef  TERN_186
#define I2CHIP_INT4
#define TERN_16_BIT
#endif                // TERN_186
#ifdef  TERN_586
#define I2CHIP_INT0
#define I2CHIP_WINDOW_IO
#endif                // TERN_586
#endif                // TERN_P51

#ifdef TERN_CEYE
#define TERN_EE       // C-Eye configured with onboard i2chip, same as EE
#endif

#ifdef TERN_EE
#define TERN_186
#define I2CHIP_MCS_DIRECT
#define I2CHIP_INT4
#define TERN_16_BIT
#endif                    // TERN_EE

#ifdef TERN_MMC
#define I2CHIP_WINDOW
#define I2CHIP_MMC
#ifdef TERN_RD
#define I2CHIP_INT3
#else
#ifdef TERN_186
#define I2CHIP_INT4
#endif                   // TERN_186
#endif                   // TERN_RD
#ifdef TERN_586
#define I2CHIP_INT0
#define I2CHIP_WINDOW_IO
#endif                   // TERN_586
#endif                   // TERN_MMC

#ifdef TERN_586
#include "586.h"
void interrupt far int0_isr(void);
void interrupt far spu_m_isr(void);
void interrupt far spu_1_isr(void);
void interrupt far spu_2_isr(void);
#define MMCR 0xdf00
#endif                   // TERN_586

#ifdef TERN_186
#ifndef TERN_RE
#include "ae.h"
#else
#include "re.h"
#define I2CHIP_SHIFTED_ADDRESS
#endif
#endif


#ifndef I2CHIP_MCS_DIRECT
#ifndef I2CHIP_WINDOW
#ifndef I2CHIP_WINDOW_IO
#error You must define the TERN address mapping used to drive the I2CHIP module!
#endif  // I2CHIP_WINDOW_IO
#endif  // I2CHIP_MMC_WINDOW
#endif  // I2CHIP_MCS_DIRECT

#ifndef I2CHIP_INT0
#ifndef I2CHIP_INT3
#ifndef I2CHIP_INT4
#ifndef I2CHIP_POLL
#error You must specify an interrupt/polling mechanism for the I2CHIP module!
#endif  // I2CHIP_POLL
#endif  // I2CHIP_INT3
#endif  // I2CHIP_INT4
#endif  // I2CHIP_INT0

#ifdef   I2CHIP_POLL
#define  I2CHIP_POLL_ISR(a)   { delay_ms(20); disable(); a(); enable(); }
#define  INT_INIT(isr)
#define  INT_EOI
#endif   // I2CHIP_POLL

#ifdef   I2CHIP_INT4
#define  INT_INIT(isr) int4_init(1, isr)
#define  INT_EOI       outport(0xff22,0x0010)
#define  I2CHIP_POLL_ISR(a)
#endif

#ifdef   I2CHIP_INT3
#define  INT_INIT(isr) int3_init(1, isr)
#define  INT_EOI       outport(0xff22,0x000f)
#define  I2CHIP_POLL_ISR(a)
#endif

#ifdef   I2CHIP_INT0
#define  INT_INIT(isr) int0_init(1, isr)
#define  INT_EOI        outportb(_MPICOCW2_IO,0x61); // 586 only EOI
#define  I2CHIP_POLL_ISR(a)
#endif


#ifdef   I2CHIP_SHIFTED_ADDRESS
#define  SA_OFFSET(a)   ((a) << 1)
#else
#define  SA_OFFSET(a)   a
#endif   // I2CHIP_SHIFTED_ADDRESS ... *if*


// -------------------- WINDOW-RELATED DEFINES ----------------------
#ifdef   I2CHIP_WINDOW
void        i2chip_set_page(u_int addr);
#define  I2CHIP_SET_PAGE(p) i2chip_set_page(p)

u_char far* i2chip_mkptr(u_int addr);
void 			i2chip_push_window(u_int addr);
void 			i2chip_pop_window(void);
u_int       i2chip_get_window(void);
void i2chip_set_window(u_int window_addr);

// Set to command window.
// Note that if you're using other MMC chips within your application, you will
// need to call this function regularly, if you've changed the MMC chip/page
// selection via mmc_window().  The driver code otherwise assume that you never
// change away from chip 7, page 0.
#define  WINDOW_RESTORE_BASE    i2chip_mkptr(0)

//  ----------------------- I2CHIP_WINDOW_IO ----------------------------
#ifdef   I2CHIP_WINDOW_IO

#ifdef   TERN_5E
#define	I2CHIP_BASE_SEG	   0x2000			// Address offset for W3100A
#else
#define	I2CHIP_BASE_SEG	   0x1800			// Address offset for W3100A
#endif

#define  COMMAND_BASE_SEG     0x0000
#define	SEND_DATA_BUF		   0x4000			// Internal Tx buffer address of W3100A
#define	RECV_DATA_BUF		   0x6000			// Internal Rx buffer address of W3100A
#define  WINDOW_BASE_SEGM     COMMAND_BASE_SEG

#define  MK_FP_WINDOW(a, b)   i2chip_mkptr(a+SA_OFFSET(b))
#define  MK_FP_SA             MK_FP_WINDOW

u_char   io_read_value(u_char far* addr);
void     io_write_value(u_char far* addr, u_char value);
#define  READ_VALUE(a)        io_read_value(a)
#define  WRITE_VALUE(a, v)    io_write_value(a, v)

#define  WINDOW_PTR_INC(a)    \
         if ((FP_OFF(a) & 0xff) == 0xff) \
            a = MK_FP_WINDOW(i2chip_get_window() + 0x100, 0); \
         else \
         	a++;

#endif  // I2CHIP_WINDOW_IO

//  -------------------- !NOT! I2CHIP_WINDOW_IO ----------------------------
#ifndef  I2CHIP_WINDOW_IO

#define  READ_VALUE(a)        *(a)
#define  WRITE_VALUE(a, v)    *(a) = v

#define  WINDOW_BASE_SEGM  0x8000
#define  MK_FP_WINDOW(a, b)   i2chip_mkptr(a+SA_OFFSET(b))
#define  MK_FP_SA  MK_FP_WINDOW

#ifdef   I2CHIP_SHIFTED_ADDRESS
#define  COMMAND_BASE_SEG  0x0000
#define  SEND_DATA_BUF     0x8000
#define  RECV_DATA_BUF     0xC000
#define  WINDOW_PTR_INC(a)    \
         if ((FP_OFF(a) & 0xff) == 0xfe) \
            a = MK_FP_WINDOW(i2chip_get_window() + 0x100, 0); \
         else \
         	a+=2;
#else
#define  COMMAND_BASE_SEG  0x0000
#define  SEND_DATA_BUF     0x4000
#define  RECV_DATA_BUF     0x6000
#define  WINDOW_PTR_INC(a)    \
         if ((FP_OFF(a) & 0xff) == 0xff) \
            a = MK_FP_WINDOW(i2chip_get_window() + 0x100, 0); \
         else \
         	a++;
#endif   // I2CHIP_SHIFTED_ADDRESS
#endif   // NOT I2CHIP_WINDOW_IO

#endif   // I2CHIP_WINDOW

//  --------------------  I2CHIP_DIRECT ----------------------------
#ifdef   I2CHIP_MCS_DIRECT

#define  READ_VALUE(a)        *(a)
#define  WRITE_VALUE(a, v)    *(a) = v

#define  I2CHIP_BASE_SEG  0x8000
#define  MK_FP_SA(a, b)   MK_FP(a, SA_OFFSET(b))
#define  WINDOW_PTR_INC(a)   a+=SA_OFFSET(1);
#define  WINDOW_RESTORE_BASE
#define  MK_FP_WINDOW           MK_FP_SA
#define  WINDOW_BASE_SEG        I2CHIP_BASE_SEG
#define  COMMAND_BASE_SEG       I2CHIP_BASE_SEG

#ifdef   I2CHIP_SHIFTED_ADDRESS
#define	SEND_DATA_BUF		0x8800			// Internal Tx buffer address of W3100A
#define	RECV_DATA_BUF		0x8C00			// Internal Rx buffer address of W3100A
#else
#define	SEND_DATA_BUF		0x8400			// Internal Tx buffer address of W3100A
#define	RECV_DATA_BUF		0x8600			// Internal Rx buffer address of W3100A
#endif   // I2CHIP_SHIFTED_ADDRESS

#endif   // I2CHIP_MCS_DIRECT

/* Internal register set of W3100A */
#define	COMMAND(i)		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, i)))
#define	INT_STATUS(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, I2CHIP_C0_ISR + i)))
#define	INT_REG   		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, I2CHIP_IR)))
#define	INTMASK     	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, I2CHIP_IMR)))
#define	RESETSOCK      ((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, 0x0A)))

#define RX_PTR_BASE		I2CHIP_C0_RW_PR
#define RX_PTR_SIZE		(I2CHIP_C1_RW_PR - I2CHIP_C0_RW_PR)

#define	RX_WR_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, RX_PTR_BASE + RX_PTR_SIZE * i)))
#define	RX_RD_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, RX_PTR_BASE + RX_PTR_SIZE * i + 0x04)))
#define	RX_ACK_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, TX_PTR_BASE + TX_PTR_SIZE * i + 0x08)))

#define TX_PTR_BASE		I2CHIP_C0_TW_PR
#define TX_PTR_SIZE		(I2CHIP_C1_TW_PR - I2CHIP_C0_TW_PR)

#define	TX_WR_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, TX_PTR_BASE + TX_PTR_SIZE * i)))
#define	TX_RD_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, TX_PTR_BASE + TX_PTR_SIZE * i + 0x04)))
#define	TX_ACK_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, RX_PTR_BASE + RX_PTR_SIZE * i + 0x08)))

/* Shadow Register Pointer Define */
/* For windowing purposes, these are definitely outside the first 256-byte Window...
therefore, use the MK_FP_WINDOW macros instead. */
#define SHADOW_RXWR_PTR(i)		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, 0x1E0 + 3*i)))
#define SHADOW_RXRD_PTR(i)		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, 0x1E1 + 3*i)))
#define SHADOW_TXACK_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, 0x1E2 + 3*i)))
#define SHADOW_TXWR_PTR(i)		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, 0x1F0 + 3*i)))
#define SHADOW_TXRD_PTR(i)		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, 0x1F1 + 3*i)))

#define SOCK_BASE		I2CHIP_C0_SSR
#define SOCK_SIZE		(I2CHIP_C1_SSR - I2CHIP_C0_SSR)

#define SOCK_STATUS(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, SOCK_BASE + SOCK_SIZE * i)))
#define OPT_PROTOCOL(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, SOCK_BASE + SOCK_SIZE * i + 0x01)))
#define DST_HA_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, SOCK_BASE + SOCK_SIZE * i + 0x02)))
#define DST_IP_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, SOCK_BASE + SOCK_SIZE * i + 0x08)))
#define DST_PORT_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, SOCK_BASE + SOCK_SIZE * i + 0x0C)))
#define SRC_PORT_PTR(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, SOCK_BASE + SOCK_SIZE * i + 0x0E)))
#define IP_PROTOCOL(i)	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, SOCK_BASE + SOCK_SIZE * i + 0x10)))
#define TOS(i)				((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG,SOCK_BASE + SOCK_SIZE * i + 0x11)))
#define MSS(i)				((u_int far *)(MK_FP_WINDOW(COMMAND_BASE_SEG, SOCK_BASE + SOCK_SIZE * i + 0x12)))
#define P_WINDOW(i)		((u_int far *)(MK_FP_WINDOW(COMMAND_BASE_SEG,SOCK_BASE + SOCK_SIZE * i + 0x14)))
#define WINDOW(i)			((u_int far*)(MK_FP_WINDOW(COMMAND_BASE_SEG, SOCK_BASE + SOCK_SIZE * i + 0x16)))

#define GATEWAY_PTR		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG,I2CHIP_GAR)))
#define SUBNET_MASK_PTR	((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG,I2CHIP_SMR)))

#define SRC_HA_PTR		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG,I2CHIP_SHAR)))
#define SRC_IP_PTR		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG,I2CHIP_SIPR)))
#define TIMEOUT_PTR		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG,I2CHIP_IRTR)))

#define RX_DMEM_SIZE		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG,I2CHIP_RMSR)))
#define TX_DMEM_SIZE		((u_char far *)(MK_FP_WINDOW(COMMAND_BASE_SEG,I2CHIP_TMSR)))

void i2chip_init(void);

#endif  // _irchip_hw_h

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产综合久久国产大片| 日本在线不卡视频| 日韩欧美激情一区| 91视频在线看| 亚洲精品日韩一| 欧美精品自拍偷拍| 91麻豆免费视频| 麻豆国产精品一区二区三区| 欧洲精品一区二区三区在线观看| 亚洲综合男人的天堂| 欧美电影免费观看高清完整版| 国产呦萝稀缺另类资源| 色爱区综合激月婷婷| 99久久久精品| 91香蕉视频mp4| 成人ar影院免费观看视频| 国内久久婷婷综合| 欧美videos大乳护士334| 久久91精品久久久久久秒播| 日本午夜精品一区二区三区电影| 亚洲成人动漫在线免费观看| 日韩一级欧美一级| 色婷婷av一区二区三区大白胸| 99综合电影在线视频| 亚洲女子a中天字幕| 亚洲自拍与偷拍| 天天综合色天天| 精品国产免费人成在线观看| 久久综合久色欧美综合狠狠| 精品裸体舞一区二区三区| 北条麻妃一区二区三区| 国产大陆精品国产| 岛国精品在线观看| 人人精品人人爱| 国产麻豆精品theporn| 国产成人在线影院| 99久久久国产精品| 91免费看片在线观看| 欧美亚洲综合久久| 91麻豆精品国产| ww久久中文字幕| 亚洲人成人一区二区在线观看| www国产成人免费观看视频 深夜成人网| 欧美成人艳星乳罩| 欧美乱妇一区二区三区不卡视频| 国产成人精品影院| 国产91丝袜在线播放| 色噜噜狠狠色综合中国| 欧美一区三区二区| 日本一区二区三级电影在线观看| 中文字幕制服丝袜一区二区三区 | 欧美成人一区二区三区片免费 | 日本韩国欧美一区| 欧美少妇一区二区| 久久久久久一二三区| 国产精品视频一二三| 欧美日韩国产经典色站一区二区三区| 亚洲精品老司机| 亚洲国产精品ⅴa在线观看| 久久久www成人免费无遮挡大片| 91精品国产综合久久精品图片| 久久精品视频一区二区| 国产91精品在线观看| 色88888久久久久久影院野外| 91精品国产综合久久久蜜臀粉嫩| 日韩美一区二区三区| 国产精品视频看| 视频一区免费在线观看| 一区二区在线观看不卡| 国产乱码精品一区二区三| 91久久香蕉国产日韩欧美9色| 久久午夜国产精品| 视频一区二区三区中文字幕| 97超碰欧美中文字幕| 2021国产精品久久精品| 美女www一区二区| 成人美女在线观看| 欧美mv日韩mv国产网站| 国产校园另类小说区| 美腿丝袜亚洲一区| 欧美性生活久久| 中文字幕在线一区| 国产精品亚洲综合一区在线观看| 7777女厕盗摄久久久| 亚洲成年人网站在线观看| 91玉足脚交白嫩脚丫在线播放| 26uuu亚洲婷婷狠狠天堂| 偷窥少妇高潮呻吟av久久免费| 国产成人精品一区二区三区四区 | 国产一区三区三区| 亚洲丝袜美腿综合| 韩国理伦片一区二区三区在线播放 | 日韩午夜精品电影| 精品国产一区二区精华 | 毛片av中文字幕一区二区| 综合久久久久久久| 日本一区二区电影| 国产一区二区三区高清播放| 成人免费高清在线| 国产日韩欧美高清| av福利精品导航| 亚洲一区二三区| 老司机精品视频在线| 日韩欧美在线影院| 国产原创一区二区| 天天综合网天天综合色 | 欧美变态tickle挠乳网站| 亚洲综合一区二区三区| 99国产一区二区三精品乱码| 亚洲激情自拍偷拍| 精品一区二区在线免费观看| 精品久久久久久久人人人人传媒| 秋霞电影网一区二区| 精品国产乱码久久久久久牛牛| 国产麻豆欧美日韩一区| 国产精品污网站| 欧美性感一区二区三区| 午夜精品爽啪视频| 精品少妇一区二区三区视频免付费| 欧美三级电影网站| 国产精品乱码一区二区三区软件| 亚洲图片有声小说| 99精品国产91久久久久久| 一区二区高清免费观看影视大全 | 欧美性受极品xxxx喷水| 国产精品久久久99| 欧美色中文字幕| 亚洲成在线观看| 91色.com| 精品在线视频一区| 亚洲自拍偷拍九九九| 日韩午夜激情电影| 99精品欧美一区二区三区小说| 视频一区二区国产| 国产成人精品亚洲日本在线桃色 | 国产欧美日韩久久| 天堂午夜影视日韩欧美一区二区| 国产一区高清在线| 久久久久久久久久久黄色| 午夜精品福利一区二区三区av | 在线视频一区二区三| 日韩午夜激情免费电影| 高清在线成人网| 久久久久久日产精品| 国内精品久久久久影院色| 国产视频不卡一区| 色综合久久久久久久久| 亚洲综合精品自拍| 91精品国产综合久久福利软件| 日韩中文字幕亚洲一区二区va在线 | av亚洲产国偷v产偷v自拍| 一区二区在线观看免费视频播放| 欧美日韩国产一级二级| 国产福利视频一区二区三区| 久久精品一区二区三区不卡| 成人avav影音| 久久国产免费看| 亚洲成av人片在线| 亚洲欧美日韩综合aⅴ视频| 欧美一区二区三区啪啪| 麻豆精品久久精品色综合| 国产精品乱码一区二区三区软件| 欧美日本一区二区在线观看| 福利电影一区二区| 日韩精品欧美精品| 亚洲免费色视频| 国产精品亲子乱子伦xxxx裸| 欧美浪妇xxxx高跟鞋交| 91丝袜高跟美女视频| 国产麻豆精品一区二区| 免费精品视频在线| 秋霞成人午夜伦在线观看| 亚洲一区二区三区三| 亚洲自拍偷拍网站| 亚洲午夜久久久久| 一区二区三区不卡视频在线观看| 最近日韩中文字幕| 欧美激情一区二区在线| 日韩女优毛片在线| 欧美一区二区三区成人| 欧美精品免费视频| 欧美一级高清片| 精品久久久久一区二区国产| 日韩一区二区三区电影在线观看| 欧美日韩aaaaa| 2023国产精华国产精品| 久久久久久久性| 中文字幕亚洲区| 一区二区三区在线观看网站| 亚洲黄色av一区| 日日摸夜夜添夜夜添精品视频| 婷婷综合在线观看| 国产成人啪免费观看软件| 成人免费看片app下载| 欧美美女喷水视频| 亚洲免费av观看| 国产成人av一区二区| 日韩精品中文字幕在线一区| 最新欧美精品一区二区三区| 国产一区二区三区香蕉|