via-ircc.h 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853
  1. /*********************************************************************
  2. *
  3. * Filename: via-ircc.h
  4. * Version: 1.0
  5. * Description: Driver for the VIA VT8231/VT8233 IrDA chipsets
  6. * Author: VIA Technologies, inc
  7. * Date : 08/06/2003
  8. Copyright (c) 1998-2003 VIA Technologies, Inc.
  9. This program is free software; you can redistribute it and/or modify it under
  10. the terms of the GNU General Public License as published by the Free Software
  11. Foundation; either version 2, or (at your option) any later version.
  12. This program is distributed in the hope that it will be useful, but WITHOUT
  13. ANY WARRANTIES OR REPRESENTATIONS; without even the implied warranty of
  14. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  15. See the GNU General Public License for more details.
  16. You should have received a copy of the GNU General Public License along with
  17. this program; if not, write to the Free Software Foundation, Inc.,
  18. 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  19. * Comment:
  20. * jul/08/2002 : Rx buffer length should use Rx ring ptr.
  21. * Oct/28/2002 : Add SB id for 3147 and 3177.
  22. * jul/09/2002 : only implement two kind of dongle currently.
  23. * Oct/02/2002 : work on VT8231 and VT8233 .
  24. * Aug/06/2003 : change driver format to pci driver .
  25. ********************************************************************/
  26. #ifndef via_IRCC_H
  27. #define via_IRCC_H
  28. #include <linux/time.h>
  29. #include <linux/spinlock.h>
  30. #include <linux/pm.h>
  31. #include <linux/types.h>
  32. #include <asm/io.h>
  33. #define MAX_TX_WINDOW 7
  34. #define MAX_RX_WINDOW 7
  35. struct st_fifo_entry {
  36. int status;
  37. int len;
  38. };
  39. struct st_fifo {
  40. struct st_fifo_entry entries[MAX_RX_WINDOW + 2];
  41. int pending_bytes;
  42. int head;
  43. int tail;
  44. int len;
  45. };
  46. struct frame_cb {
  47. void *start; /* Start of frame in DMA mem */
  48. int len; /* Lenght of frame in DMA mem */
  49. };
  50. struct tx_fifo {
  51. struct frame_cb queue[MAX_TX_WINDOW + 2]; /* Info about frames in queue */
  52. int ptr; /* Currently being sent */
  53. int len; /* Lenght of queue */
  54. int free; /* Next free slot */
  55. void *tail; /* Next free start in DMA mem */
  56. };
  57. struct eventflag // for keeping track of Interrupt Events
  58. {
  59. //--------tx part
  60. unsigned char TxFIFOUnderRun;
  61. unsigned char EOMessage;
  62. unsigned char TxFIFOReady;
  63. unsigned char EarlyEOM;
  64. //--------rx part
  65. unsigned char PHYErr;
  66. unsigned char CRCErr;
  67. unsigned char RxFIFOOverRun;
  68. unsigned char EOPacket;
  69. unsigned char RxAvail;
  70. unsigned char TooLargePacket;
  71. unsigned char SIRBad;
  72. //--------unknown
  73. unsigned char Unknown;
  74. //----------
  75. unsigned char TimeOut;
  76. unsigned char RxDMATC;
  77. unsigned char TxDMATC;
  78. };
  79. /* Private data for each instance */
  80. struct via_ircc_cb {
  81. struct st_fifo st_fifo; /* Info about received frames */
  82. struct tx_fifo tx_fifo; /* Info about frames to be transmitted */
  83. struct net_device *netdev; /* Yes! we are some kind of netdevice */
  84. struct net_device_stats stats;
  85. struct irlap_cb *irlap; /* The link layer we are binded to */
  86. struct qos_info qos; /* QoS capabilities for this device */
  87. chipio_t io; /* IrDA controller information */
  88. iobuff_t tx_buff; /* Transmit buffer */
  89. iobuff_t rx_buff; /* Receive buffer */
  90. dma_addr_t tx_buff_dma;
  91. dma_addr_t rx_buff_dma;
  92. __u8 ier; /* Interrupt enable register */
  93. struct timeval stamp;
  94. struct timeval now;
  95. spinlock_t lock; /* For serializing operations */
  96. __u32 flags; /* Interface flags */
  97. __u32 new_speed;
  98. int index; /* Instance index */
  99. struct eventflag EventFlag;
  100. struct pm_dev *dev;
  101. unsigned int chip_id; /* to remember chip id */
  102. unsigned int RetryCount;
  103. unsigned int RxDataReady;
  104. unsigned int RxLastCount;
  105. };
  106. //---------I=Infrared, H=Host, M=Misc, T=Tx, R=Rx, ST=Status,
  107. // CF=Config, CT=Control, L=Low, H=High, C=Count
  108. #define I_CF_L_0 0x10
  109. #define I_CF_H_0 0x11
  110. #define I_SIR_BOF 0x12
  111. #define I_SIR_EOF 0x13
  112. #define I_ST_CT_0 0x15
  113. #define I_ST_L_1 0x16
  114. #define I_ST_H_1 0x17
  115. #define I_CF_L_1 0x18
  116. #define I_CF_H_1 0x19
  117. #define I_CF_L_2 0x1a
  118. #define I_CF_H_2 0x1b
  119. #define I_CF_3 0x1e
  120. #define H_CT 0x20
  121. #define H_ST 0x21
  122. #define M_CT 0x22
  123. #define TX_CT_1 0x23
  124. #define TX_CT_2 0x24
  125. #define TX_ST 0x25
  126. #define RX_CT 0x26
  127. #define RX_ST 0x27
  128. #define RESET 0x28
  129. #define P_ADDR 0x29
  130. #define RX_C_L 0x2a
  131. #define RX_C_H 0x2b
  132. #define RX_P_L 0x2c
  133. #define RX_P_H 0x2d
  134. #define TX_C_L 0x2e
  135. #define TX_C_H 0x2f
  136. #define TIMER 0x32
  137. #define I_CF_4 0x33
  138. #define I_T_C_L 0x34
  139. #define I_T_C_H 0x35
  140. #define VERSION 0x3f
  141. //-------------------------------
  142. #define StartAddr 0x10 // the first register address
  143. #define EndAddr 0x3f // the last register address
  144. #define GetBit(val,bit) val = (unsigned char) ((val>>bit) & 0x1)
  145. // Returns the bit
  146. #define SetBit(val,bit) val= (unsigned char ) (val | (0x1 << bit))
  147. // Sets bit to 1
  148. #define ResetBit(val,bit) val= (unsigned char ) (val & ~(0x1 << bit))
  149. // Sets bit to 0
  150. #define OFF 0
  151. #define ON 1
  152. #define DMA_TX_MODE 0x08
  153. #define DMA_RX_MODE 0x04
  154. #define DMA1 0
  155. #define DMA2 0xc0
  156. #define MASK1 DMA1+0x0a
  157. #define MASK2 DMA2+0x14
  158. #define Clk_bit 0x40
  159. #define Tx_bit 0x01
  160. #define Rd_Valid 0x08
  161. #define RxBit 0x08
  162. static void DisableDmaChannel(unsigned int channel)
  163. {
  164. switch (channel) { // 8 Bit DMA channels DMAC1
  165. case 0:
  166. outb(4, MASK1); //mask channel 0
  167. break;
  168. case 1:
  169. outb(5, MASK1); //Mask channel 1
  170. break;
  171. case 2:
  172. outb(6, MASK1); //Mask channel 2
  173. break;
  174. case 3:
  175. outb(7, MASK1); //Mask channel 3
  176. break;
  177. case 5:
  178. outb(5, MASK2); //Mask channel 5
  179. break;
  180. case 6:
  181. outb(6, MASK2); //Mask channel 6
  182. break;
  183. case 7:
  184. outb(7, MASK2); //Mask channel 7
  185. break;
  186. default:
  187. break;
  188. }; //Switch
  189. }
  190. static unsigned char ReadLPCReg(int iRegNum)
  191. {
  192. unsigned char iVal;
  193. outb(0x87, 0x2e);
  194. outb(0x87, 0x2e);
  195. outb(iRegNum, 0x2e);
  196. iVal = inb(0x2f);
  197. outb(0xaa, 0x2e);
  198. return iVal;
  199. }
  200. static void WriteLPCReg(int iRegNum, unsigned char iVal)
  201. {
  202. outb(0x87, 0x2e);
  203. outb(0x87, 0x2e);
  204. outb(iRegNum, 0x2e);
  205. outb(iVal, 0x2f);
  206. outb(0xAA, 0x2e);
  207. }
  208. static __u8 ReadReg(unsigned int BaseAddr, int iRegNum)
  209. {
  210. return ((__u8) inb(BaseAddr + iRegNum));
  211. }
  212. static void WriteReg(unsigned int BaseAddr, int iRegNum, unsigned char iVal)
  213. {
  214. outb(iVal, BaseAddr + iRegNum);
  215. }
  216. static int WriteRegBit(unsigned int BaseAddr, unsigned char RegNum,
  217. unsigned char BitPos, unsigned char value)
  218. {
  219. __u8 Rtemp, Wtemp;
  220. if (BitPos > 7) {
  221. return -1;
  222. }
  223. if ((RegNum < StartAddr) || (RegNum > EndAddr))
  224. return -1;
  225. Rtemp = ReadReg(BaseAddr, RegNum);
  226. if (value == 0)
  227. Wtemp = ResetBit(Rtemp, BitPos);
  228. else {
  229. if (value == 1)
  230. Wtemp = SetBit(Rtemp, BitPos);
  231. else
  232. return -1;
  233. }
  234. WriteReg(BaseAddr, RegNum, Wtemp);
  235. return 0;
  236. }
  237. static __u8 CheckRegBit(unsigned int BaseAddr, unsigned char RegNum,
  238. unsigned char BitPos)
  239. {
  240. __u8 temp;
  241. if (BitPos > 7)
  242. return 0xff;
  243. if ((RegNum < StartAddr) || (RegNum > EndAddr)) {
  244. // printf("what is the register %x!\n",RegNum);
  245. }
  246. temp = ReadReg(BaseAddr, RegNum);
  247. return GetBit(temp, BitPos);
  248. }
  249. static void SetMaxRxPacketSize(__u16 iobase, __u16 size)
  250. {
  251. __u16 low, high;
  252. if ((size & 0xe000) == 0) {
  253. low = size & 0x00ff;
  254. high = (size & 0x1f00) >> 8;
  255. WriteReg(iobase, I_CF_L_2, low);
  256. WriteReg(iobase, I_CF_H_2, high);
  257. }
  258. }
  259. //for both Rx and Tx
  260. static void SetFIFO(__u16 iobase, __u16 value)
  261. {
  262. switch (value) {
  263. case 128:
  264. WriteRegBit(iobase, 0x11, 0, 0);
  265. WriteRegBit(iobase, 0x11, 7, 1);
  266. break;
  267. case 64:
  268. WriteRegBit(iobase, 0x11, 0, 0);
  269. WriteRegBit(iobase, 0x11, 7, 0);
  270. break;
  271. case 32:
  272. WriteRegBit(iobase, 0x11, 0, 1);
  273. WriteRegBit(iobase, 0x11, 7, 0);
  274. break;
  275. default:
  276. WriteRegBit(iobase, 0x11, 0, 0);
  277. WriteRegBit(iobase, 0x11, 7, 0);
  278. }
  279. }
  280. #define CRC16(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_L_0,7,val) //0 for 32 CRC
  281. /*
  282. #define SetVFIR(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_H_0,5,val)
  283. #define SetFIR(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_L_0,6,val)
  284. #define SetMIR(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_L_0,5,val)
  285. #define SetSIR(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_L_0,4,val)
  286. */
  287. #define SIRFilter(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_L_0,3,val)
  288. #define Filter(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_L_0,2,val)
  289. #define InvertTX(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_L_0,1,val)
  290. #define InvertRX(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_L_0,0,val)
  291. //****************************I_CF_H_0
  292. #define EnableTX(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_H_0,4,val)
  293. #define EnableRX(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_H_0,3,val)
  294. #define EnableDMA(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_H_0,2,val)
  295. #define SIRRecvAny(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_H_0,1,val)
  296. #define DiableTrans(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_H_0,0,val)
  297. //***************************I_SIR_BOF,I_SIR_EOF
  298. #define SetSIRBOF(BaseAddr,val) WriteReg(BaseAddr,I_SIR_BOF,val)
  299. #define SetSIREOF(BaseAddr,val) WriteReg(BaseAddr,I_SIR_EOF,val)
  300. #define GetSIRBOF(BaseAddr) ReadReg(BaseAddr,I_SIR_BOF)
  301. #define GetSIREOF(BaseAddr) ReadReg(BaseAddr,I_SIR_EOF)
  302. //*******************I_ST_CT_0
  303. #define EnPhys(BaseAddr,val) WriteRegBit(BaseAddr,I_ST_CT_0,7,val)
  304. #define IsModeError(BaseAddr) CheckRegBit(BaseAddr,I_ST_CT_0,6) //RO
  305. #define IsVFIROn(BaseAddr) CheckRegBit(BaseAddr,0x14,0) //RO for VT1211 only
  306. #define IsFIROn(BaseAddr) CheckRegBit(BaseAddr,I_ST_CT_0,5) //RO
  307. #define IsMIROn(BaseAddr) CheckRegBit(BaseAddr,I_ST_CT_0,4) //RO
  308. #define IsSIROn(BaseAddr) CheckRegBit(BaseAddr,I_ST_CT_0,3) //RO
  309. #define IsEnableTX(BaseAddr) CheckRegBit(BaseAddr,I_ST_CT_0,2) //RO
  310. #define IsEnableRX(BaseAddr) CheckRegBit(BaseAddr,I_ST_CT_0,1) //RO
  311. #define Is16CRC(BaseAddr) CheckRegBit(BaseAddr,I_ST_CT_0,0) //RO
  312. //***************************I_CF_3
  313. #define DisableAdjacentPulseWidth(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_3,5,val) //1 disable
  314. #define DisablePulseWidthAdjust(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_3,4,val) //1 disable
  315. #define UseOneRX(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_3,1,val) //0 use two RX
  316. #define SlowIRRXLowActive(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_3,0,val) //0 show RX high=1 in SIR
  317. //***************************H_CT
  318. #define EnAllInt(BaseAddr,val) WriteRegBit(BaseAddr,H_CT,7,val)
  319. #define TXStart(BaseAddr,val) WriteRegBit(BaseAddr,H_CT,6,val)
  320. #define RXStart(BaseAddr,val) WriteRegBit(BaseAddr,H_CT,5,val)
  321. #define ClearRXInt(BaseAddr,val) WriteRegBit(BaseAddr,H_CT,4,val) // 1 clear
  322. //*****************H_ST
  323. #define IsRXInt(BaseAddr) CheckRegBit(BaseAddr,H_ST,4)
  324. #define GetIntIndentify(BaseAddr) ((ReadReg(BaseAddr,H_ST)&0xf1) >>1)
  325. #define IsHostBusy(BaseAddr) CheckRegBit(BaseAddr,H_ST,0)
  326. #define GetHostStatus(BaseAddr) ReadReg(BaseAddr,H_ST) //RO
  327. //**************************M_CT
  328. #define EnTXDMA(BaseAddr,val) WriteRegBit(BaseAddr,M_CT,7,val)
  329. #define EnRXDMA(BaseAddr,val) WriteRegBit(BaseAddr,M_CT,6,val)
  330. #define SwapDMA(BaseAddr,val) WriteRegBit(BaseAddr,M_CT,5,val)
  331. #define EnInternalLoop(BaseAddr,val) WriteRegBit(BaseAddr,M_CT,4,val)
  332. #define EnExternalLoop(BaseAddr,val) WriteRegBit(BaseAddr,M_CT,3,val)
  333. //**************************TX_CT_1
  334. #define EnTXFIFOHalfLevelInt(BaseAddr,val) WriteRegBit(BaseAddr,TX_CT_1,4,val) //half empty int (1 half)
  335. #define EnTXFIFOUnderrunEOMInt(BaseAddr,val) WriteRegBit(BaseAddr,TX_CT_1,5,val)
  336. #define EnTXFIFOReadyInt(BaseAddr,val) WriteRegBit(BaseAddr,TX_CT_1,6,val) //int when reach it threshold (setting by bit 4)
  337. //**************************TX_CT_2
  338. #define ForceUnderrun(BaseAddr,val) WriteRegBit(BaseAddr,TX_CT_2,7,val) // force an underrun int
  339. #define EnTXCRC(BaseAddr,val) WriteRegBit(BaseAddr,TX_CT_2,6,val) //1 for FIR,MIR...0 (not SIR)
  340. #define ForceBADCRC(BaseAddr,val) WriteRegBit(BaseAddr,TX_CT_2,5,val) //force an bad CRC
  341. #define SendSIP(BaseAddr,val) WriteRegBit(BaseAddr,TX_CT_2,4,val) //send indication pulse for prevent SIR disturb
  342. #define ClearEnTX(BaseAddr,val) WriteRegBit(BaseAddr,TX_CT_2,3,val) // opposite to EnTX
  343. //*****************TX_ST
  344. #define GetTXStatus(BaseAddr) ReadReg(BaseAddr,TX_ST) //RO
  345. //**************************RX_CT
  346. #define EnRXSpecInt(BaseAddr,val) WriteRegBit(BaseAddr,RX_CT,0,val)
  347. #define EnRXFIFOReadyInt(BaseAddr,val) WriteRegBit(BaseAddr,RX_CT,1,val) //enable int when reach it threshold (setting by bit 7)
  348. #define EnRXFIFOHalfLevelInt(BaseAddr,val) WriteRegBit(BaseAddr,RX_CT,7,val) //enable int when (1) half full...or (0) just not full
  349. //*****************RX_ST
  350. #define GetRXStatus(BaseAddr) ReadReg(BaseAddr,RX_ST) //RO
  351. //***********************P_ADDR
  352. #define SetPacketAddr(BaseAddr,addr) WriteReg(BaseAddr,P_ADDR,addr)
  353. //***********************I_CF_4
  354. #define EnGPIOtoRX2(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_4,7,val)
  355. #define EnTimerInt(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_4,1,val)
  356. #define ClearTimerInt(BaseAddr,val) WriteRegBit(BaseAddr,I_CF_4,0,val)
  357. //***********************I_T_C_L
  358. #define WriteGIO(BaseAddr,val) WriteRegBit(BaseAddr,I_T_C_L,7,val)
  359. #define ReadGIO(BaseAddr) CheckRegBit(BaseAddr,I_T_C_L,7)
  360. #define ReadRX(BaseAddr) CheckRegBit(BaseAddr,I_T_C_L,3) //RO
  361. #define WriteTX(BaseAddr,val) WriteRegBit(BaseAddr,I_T_C_L,0,val)
  362. //***********************I_T_C_H
  363. #define EnRX2(BaseAddr,val) WriteRegBit(BaseAddr,I_T_C_H,7,val)
  364. #define ReadRX2(BaseAddr) CheckRegBit(BaseAddr,I_T_C_H,7)
  365. //**********************Version
  366. #define GetFIRVersion(BaseAddr) ReadReg(BaseAddr,VERSION)
  367. static void SetTimer(__u16 iobase, __u8 count)
  368. {
  369. EnTimerInt(iobase, OFF);
  370. WriteReg(iobase, TIMER, count);
  371. EnTimerInt(iobase, ON);
  372. }
  373. static void SetSendByte(__u16 iobase, __u32 count)
  374. {
  375. __u32 low, high;
  376. if ((count & 0xf000) == 0) {
  377. low = count & 0x00ff;
  378. high = (count & 0x0f00) >> 8;
  379. WriteReg(iobase, TX_C_L, low);
  380. WriteReg(iobase, TX_C_H, high);
  381. }
  382. }
  383. static void ResetChip(__u16 iobase, __u8 type)
  384. {
  385. __u8 value;
  386. value = (type + 2) << 4;
  387. WriteReg(iobase, RESET, type);
  388. }
  389. static int CkRxRecv(__u16 iobase, struct via_ircc_cb *self)
  390. {
  391. __u8 low, high;
  392. __u16 wTmp = 0, wTmp1 = 0, wTmp_new = 0;
  393. low = ReadReg(iobase, RX_C_L);
  394. high = ReadReg(iobase, RX_C_H);
  395. wTmp1 = high;
  396. wTmp = (wTmp1 << 8) | low;
  397. udelay(10);
  398. low = ReadReg(iobase, RX_C_L);
  399. high = ReadReg(iobase, RX_C_H);
  400. wTmp1 = high;
  401. wTmp_new = (wTmp1 << 8) | low;
  402. if (wTmp_new != wTmp)
  403. return 1;
  404. else
  405. return 0;
  406. }
  407. static __u16 RxCurCount(__u16 iobase, struct via_ircc_cb * self)
  408. {
  409. __u8 low, high;
  410. __u16 wTmp = 0, wTmp1 = 0;
  411. low = ReadReg(iobase, RX_P_L);
  412. high = ReadReg(iobase, RX_P_H);
  413. wTmp1 = high;
  414. wTmp = (wTmp1 << 8) | low;
  415. return wTmp;
  416. }
  417. /* This Routine can only use in recevie_complete
  418. * for it will update last count.
  419. */
  420. static __u16 GetRecvByte(__u16 iobase, struct via_ircc_cb * self)
  421. {
  422. __u8 low, high;
  423. __u16 wTmp, wTmp1, ret;
  424. low = ReadReg(iobase, RX_P_L);
  425. high = ReadReg(iobase, RX_P_H);
  426. wTmp1 = high;
  427. wTmp = (wTmp1 << 8) | low;
  428. if (wTmp >= self->RxLastCount)
  429. ret = wTmp - self->RxLastCount;
  430. else
  431. ret = (0x8000 - self->RxLastCount) + wTmp;
  432. self->RxLastCount = wTmp;
  433. /* RX_P is more actually the RX_C
  434. low=ReadReg(iobase,RX_C_L);
  435. high=ReadReg(iobase,RX_C_H);
  436. if(!(high&0xe000)) {
  437. temp=(high<<8)+low;
  438. return temp;
  439. }
  440. else return 0;
  441. */
  442. return ret;
  443. }
  444. static void Sdelay(__u16 scale)
  445. {
  446. __u8 bTmp;
  447. int i, j;
  448. for (j = 0; j < scale; j++) {
  449. for (i = 0; i < 0x20; i++) {
  450. bTmp = inb(0xeb);
  451. outb(bTmp, 0xeb);
  452. }
  453. }
  454. }
  455. static void Tdelay(__u16 scale)
  456. {
  457. __u8 bTmp;
  458. int i, j;
  459. for (j = 0; j < scale; j++) {
  460. for (i = 0; i < 0x50; i++) {
  461. bTmp = inb(0xeb);
  462. outb(bTmp, 0xeb);
  463. }
  464. }
  465. }
  466. static void ActClk(__u16 iobase, __u8 value)
  467. {
  468. __u8 bTmp;
  469. bTmp = ReadReg(iobase, 0x34);
  470. if (value)
  471. WriteReg(iobase, 0x34, bTmp | Clk_bit);
  472. else
  473. WriteReg(iobase, 0x34, bTmp & ~Clk_bit);
  474. }
  475. static void ClkTx(__u16 iobase, __u8 Clk, __u8 Tx)
  476. {
  477. __u8 bTmp;
  478. bTmp = ReadReg(iobase, 0x34);
  479. if (Clk == 0)
  480. bTmp &= ~Clk_bit;
  481. else {
  482. if (Clk == 1)
  483. bTmp |= Clk_bit;
  484. }
  485. WriteReg(iobase, 0x34, bTmp);
  486. Sdelay(1);
  487. if (Tx == 0)
  488. bTmp &= ~Tx_bit;
  489. else {
  490. if (Tx == 1)
  491. bTmp |= Tx_bit;
  492. }
  493. WriteReg(iobase, 0x34, bTmp);
  494. }
  495. static void Wr_Byte(__u16 iobase, __u8 data)
  496. {
  497. __u8 bData = data;
  498. // __u8 btmp;
  499. int i;
  500. ClkTx(iobase, 0, 1);
  501. Tdelay(2);
  502. ActClk(iobase, 1);
  503. Tdelay(1);
  504. for (i = 0; i < 8; i++) { //LDN
  505. if ((bData >> i) & 0x01) {
  506. ClkTx(iobase, 0, 1); //bit data = 1;
  507. } else {
  508. ClkTx(iobase, 0, 0); //bit data = 1;
  509. }
  510. Tdelay(2);
  511. Sdelay(1);
  512. ActClk(iobase, 1); //clk hi
  513. Tdelay(1);
  514. }
  515. }
  516. static __u8 Rd_Indx(__u16 iobase, __u8 addr, __u8 index)
  517. {
  518. __u8 data = 0, bTmp, data_bit;
  519. int i;
  520. bTmp = addr | (index << 1) | 0;
  521. ClkTx(iobase, 0, 0);
  522. Tdelay(2);
  523. ActClk(iobase, 1);
  524. udelay(1);
  525. Wr_Byte(iobase, bTmp);
  526. Sdelay(1);
  527. ClkTx(iobase, 0, 0);
  528. Tdelay(2);
  529. for (i = 0; i < 10; i++) {
  530. ActClk(iobase, 1);
  531. Tdelay(1);
  532. ActClk(iobase, 0);
  533. Tdelay(1);
  534. ClkTx(iobase, 0, 1);
  535. Tdelay(1);
  536. bTmp = ReadReg(iobase, 0x34);
  537. if (!(bTmp & Rd_Valid))
  538. break;
  539. }
  540. if (!(bTmp & Rd_Valid)) {
  541. for (i = 0; i < 8; i++) {
  542. ActClk(iobase, 1);
  543. Tdelay(1);
  544. ActClk(iobase, 0);
  545. bTmp = ReadReg(iobase, 0x34);
  546. data_bit = 1 << i;
  547. if (bTmp & RxBit)
  548. data |= data_bit;
  549. else
  550. data &= ~data_bit;
  551. Tdelay(2);
  552. }
  553. } else {
  554. for (i = 0; i < 2; i++) {
  555. ActClk(iobase, 1);
  556. Tdelay(1);
  557. ActClk(iobase, 0);
  558. Tdelay(2);
  559. }
  560. bTmp = ReadReg(iobase, 0x34);
  561. }
  562. for (i = 0; i < 1; i++) {
  563. ActClk(iobase, 1);
  564. Tdelay(1);
  565. ActClk(iobase, 0);
  566. Tdelay(2);
  567. }
  568. ClkTx(iobase, 0, 0);
  569. Tdelay(1);
  570. for (i = 0; i < 3; i++) {
  571. ActClk(iobase, 1);
  572. Tdelay(1);
  573. ActClk(iobase, 0);
  574. Tdelay(2);
  575. }
  576. return data;
  577. }
  578. static void Wr_Indx(__u16 iobase, __u8 addr, __u8 index, __u8 data)
  579. {
  580. int i;
  581. __u8 bTmp;
  582. ClkTx(iobase, 0, 0);
  583. udelay(2);
  584. ActClk(iobase, 1);
  585. udelay(1);
  586. bTmp = addr | (index << 1) | 1;
  587. Wr_Byte(iobase, bTmp);
  588. Wr_Byte(iobase, data);
  589. for (i = 0; i < 2; i++) {
  590. ClkTx(iobase, 0, 0);
  591. Tdelay(2);
  592. ActClk(iobase, 1);
  593. Tdelay(1);
  594. }
  595. ActClk(iobase, 0);
  596. }
  597. static void ResetDongle(__u16 iobase)
  598. {
  599. int i;
  600. ClkTx(iobase, 0, 0);
  601. Tdelay(1);
  602. for (i = 0; i < 30; i++) {
  603. ActClk(iobase, 1);
  604. Tdelay(1);
  605. ActClk(iobase, 0);
  606. Tdelay(1);
  607. }
  608. ActClk(iobase, 0);
  609. }
  610. static void SetSITmode(__u16 iobase)
  611. {
  612. __u8 bTmp;
  613. bTmp = ReadLPCReg(0x28);
  614. WriteLPCReg(0x28, bTmp | 0x10); //select ITMOFF
  615. bTmp = ReadReg(iobase, 0x35);
  616. WriteReg(iobase, 0x35, bTmp | 0x40); // Driver ITMOFF
  617. WriteReg(iobase, 0x28, bTmp | 0x80); // enable All interrupt
  618. }
  619. static void SI_SetMode(__u16 iobase, int mode)
  620. {
  621. //__u32 dTmp;
  622. __u8 bTmp;
  623. WriteLPCReg(0x28, 0x70); // S/W Reset
  624. SetSITmode(iobase);
  625. ResetDongle(iobase);
  626. udelay(10);
  627. Wr_Indx(iobase, 0x40, 0x0, 0x17); //RX ,APEN enable,Normal power
  628. Wr_Indx(iobase, 0x40, 0x1, mode); //Set Mode
  629. Wr_Indx(iobase, 0x40, 0x2, 0xff); //Set power to FIR VFIR > 1m
  630. bTmp = Rd_Indx(iobase, 0x40, 1);
  631. }
  632. static void InitCard(__u16 iobase)
  633. {
  634. ResetChip(iobase, 5);
  635. WriteReg(iobase, I_ST_CT_0, 0x00); // open CHIP on
  636. SetSIRBOF(iobase, 0xc0); // hardware default value
  637. SetSIREOF(iobase, 0xc1);
  638. }
  639. static void CommonInit(__u16 iobase)
  640. {
  641. // EnTXCRC(iobase,0);
  642. SwapDMA(iobase, OFF);
  643. SetMaxRxPacketSize(iobase, 0x0fff); //set to max:4095
  644. EnRXFIFOReadyInt(iobase, OFF);
  645. EnRXFIFOHalfLevelInt(iobase, OFF);
  646. EnTXFIFOHalfLevelInt(iobase, OFF);
  647. EnTXFIFOUnderrunEOMInt(iobase, ON);
  648. // EnTXFIFOReadyInt(iobase,ON);
  649. InvertTX(iobase, OFF);
  650. InvertRX(iobase, OFF);
  651. // WriteLPCReg(0xF0,0); //(if VT1211 then do this)
  652. if (IsSIROn(iobase)) {
  653. SIRFilter(iobase, ON);
  654. SIRRecvAny(iobase, ON);
  655. } else {
  656. SIRFilter(iobase, OFF);
  657. SIRRecvAny(iobase, OFF);
  658. }
  659. EnRXSpecInt(iobase, ON);
  660. WriteReg(iobase, I_ST_CT_0, 0x80);
  661. EnableDMA(iobase, ON);
  662. }
  663. static void SetBaudRate(__u16 iobase, __u32 rate)
  664. {
  665. __u8 value = 11, temp;
  666. if (IsSIROn(iobase)) {
  667. switch (rate) {
  668. case (__u32) (2400L):
  669. value = 47;
  670. break;
  671. case (__u32) (9600L):
  672. value = 11;
  673. break;
  674. case (__u32) (19200L):
  675. value = 5;
  676. break;
  677. case (__u32) (38400L):
  678. value = 2;
  679. break;
  680. case (__u32) (57600L):
  681. value = 1;
  682. break;
  683. case (__u32) (115200L):
  684. value = 0;
  685. break;
  686. default:
  687. break;
  688. };
  689. } else if (IsMIROn(iobase)) {
  690. value = 0; // will automatically be fixed in 1.152M
  691. } else if (IsFIROn(iobase)) {
  692. value = 0; // will automatically be fixed in 4M
  693. }
  694. temp = (ReadReg(iobase, I_CF_H_1) & 0x03);
  695. temp |= value << 2;
  696. WriteReg(iobase, I_CF_H_1, temp);
  697. }
  698. static void SetPulseWidth(__u16 iobase, __u8 width)
  699. {
  700. __u8 temp, temp1, temp2;
  701. temp = (ReadReg(iobase, I_CF_L_1) & 0x1f);
  702. temp1 = (ReadReg(iobase, I_CF_H_1) & 0xfc);
  703. temp2 = (width & 0x07) << 5;
  704. temp |= temp2;
  705. temp2 = (width & 0x18) >> 3;
  706. temp1 |= temp2;
  707. WriteReg(iobase, I_CF_L_1, temp);
  708. WriteReg(iobase, I_CF_H_1, temp1);
  709. }
  710. static void SetSendPreambleCount(__u16 iobase, __u8 count)
  711. {
  712. __u8 temp;
  713. temp = ReadReg(iobase, I_CF_L_1) & 0xe0;
  714. temp |= count;
  715. WriteReg(iobase, I_CF_L_1, temp);
  716. }
  717. static void SetVFIR(__u16 BaseAddr, __u8 val)
  718. {
  719. __u8 tmp;
  720. tmp = ReadReg(BaseAddr, I_CF_L_0);
  721. WriteReg(BaseAddr, I_CF_L_0, tmp & 0x8f);
  722. WriteRegBit(BaseAddr, I_CF_H_0, 5, val);
  723. }
  724. static void SetFIR(__u16 BaseAddr, __u8 val)
  725. {
  726. __u8 tmp;
  727. WriteRegBit(BaseAddr, I_CF_H_0, 5, 0);
  728. tmp = ReadReg(BaseAddr, I_CF_L_0);
  729. WriteReg(BaseAddr, I_CF_L_0, tmp & 0x8f);
  730. WriteRegBit(BaseAddr, I_CF_L_0, 6, val);
  731. }
  732. static void SetMIR(__u16 BaseAddr, __u8 val)
  733. {
  734. __u8 tmp;
  735. WriteRegBit(BaseAddr, I_CF_H_0, 5, 0);
  736. tmp = ReadReg(BaseAddr, I_CF_L_0);
  737. WriteReg(BaseAddr, I_CF_L_0, tmp & 0x8f);
  738. WriteRegBit(BaseAddr, I_CF_L_0, 5, val);
  739. }
  740. static void SetSIR(__u16 BaseAddr, __u8 val)
  741. {
  742. __u8 tmp;
  743. WriteRegBit(BaseAddr, I_CF_H_0, 5, 0);
  744. tmp = ReadReg(BaseAddr, I_CF_L_0);
  745. WriteReg(BaseAddr, I_CF_L_0, tmp & 0x8f);
  746. WriteRegBit(BaseAddr, I_CF_L_0, 4, val);
  747. }
  748. #endif /* via_IRCC_H */