elsa.c 33 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190
  1. /* $Id: elsa.c,v 2.32.2.4 2004/01/24 20:47:21 keil Exp $
  2. *
  3. * low level stuff for Elsa isdn cards
  4. *
  5. * Author Karsten Keil
  6. * Copyright by Karsten Keil <keil@isdn4linux.de>
  7. *
  8. * This software may be used and distributed according to the terms
  9. * of the GNU General Public License, incorporated herein by reference.
  10. *
  11. * For changes and modifications please read
  12. * Documentation/isdn/HiSax.cert
  13. *
  14. * Thanks to Elsa GmbH for documents and information
  15. *
  16. * Klaus Lichtenwalder (Klaus.Lichtenwalder@WebForum.DE)
  17. * for ELSA PCMCIA support
  18. *
  19. */
  20. #include <linux/init.h>
  21. #include <linux/config.h>
  22. #include "hisax.h"
  23. #include "arcofi.h"
  24. #include "isac.h"
  25. #include "ipac.h"
  26. #include "hscx.h"
  27. #include "isdnl1.h"
  28. #include <linux/pci.h>
  29. #include <linux/isapnp.h>
  30. #include <linux/serial.h>
  31. #include <linux/serial_reg.h>
  32. extern const char *CardType[];
  33. static const char *Elsa_revision = "$Revision: 2.32.2.4 $";
  34. static const char *Elsa_Types[] =
  35. {"None", "PC", "PCC-8", "PCC-16", "PCF", "PCF-Pro",
  36. "PCMCIA", "QS 1000", "QS 3000", "Microlink PCI", "QS 3000 PCI",
  37. "PCMCIA-IPAC" };
  38. static const char *ITACVer[] =
  39. {"?0?", "?1?", "?2?", "?3?", "?4?", "V2.2",
  40. "B1", "A1"};
  41. #define byteout(addr,val) outb(val,addr)
  42. #define bytein(addr) inb(addr)
  43. #define ELSA_ISAC 0
  44. #define ELSA_ISAC_PCM 1
  45. #define ELSA_ITAC 1
  46. #define ELSA_HSCX 2
  47. #define ELSA_ALE 3
  48. #define ELSA_ALE_PCM 4
  49. #define ELSA_CONTROL 4
  50. #define ELSA_CONFIG 5
  51. #define ELSA_START_TIMER 6
  52. #define ELSA_TRIG_IRQ 7
  53. #define ELSA_PC 1
  54. #define ELSA_PCC8 2
  55. #define ELSA_PCC16 3
  56. #define ELSA_PCF 4
  57. #define ELSA_PCFPRO 5
  58. #define ELSA_PCMCIA 6
  59. #define ELSA_QS1000 7
  60. #define ELSA_QS3000 8
  61. #define ELSA_QS1000PCI 9
  62. #define ELSA_QS3000PCI 10
  63. #define ELSA_PCMCIA_IPAC 11
  64. /* PCI stuff */
  65. #define ELSA_PCI_IRQ_MASK 0x04
  66. /* ITAC Registeradressen (only Microlink PC) */
  67. #define ITAC_SYS 0x34
  68. #define ITAC_ISEN 0x48
  69. #define ITAC_RFIE 0x4A
  70. #define ITAC_XFIE 0x4C
  71. #define ITAC_SCIE 0x4E
  72. #define ITAC_STIE 0x46
  73. /*** ***
  74. *** Makros als Befehle fuer die Kartenregister ***
  75. *** (mehrere Befehle werden durch Bit-Oderung kombiniert) ***
  76. *** ***/
  77. /* Config-Register (Read) */
  78. #define ELSA_TIMER_RUN 0x02 /* Bit 1 des Config-Reg */
  79. #define ELSA_TIMER_RUN_PCC8 0x01 /* Bit 0 des Config-Reg bei PCC */
  80. #define ELSA_IRQ_IDX 0x38 /* Bit 3,4,5 des Config-Reg */
  81. #define ELSA_IRQ_IDX_PCC8 0x30 /* Bit 4,5 des Config-Reg */
  82. #define ELSA_IRQ_IDX_PC 0x0c /* Bit 2,3 des Config-Reg */
  83. /* Control-Register (Write) */
  84. #define ELSA_LINE_LED 0x02 /* Bit 1 Gelbe LED */
  85. #define ELSA_STAT_LED 0x08 /* Bit 3 Gruene LED */
  86. #define ELSA_ISDN_RESET 0x20 /* Bit 5 Reset-Leitung */
  87. #define ELSA_ENA_TIMER_INT 0x80 /* Bit 7 Freigabe Timer Interrupt */
  88. /* ALE-Register (Read) */
  89. #define ELSA_HW_RELEASE 0x07 /* Bit 0-2 Hardwarerkennung */
  90. #define ELSA_S0_POWER_BAD 0x08 /* Bit 3 S0-Bus Spannung fehlt */
  91. /* Status Flags */
  92. #define ELSA_TIMER_AKTIV 1
  93. #define ELSA_BAD_PWR 2
  94. #define ELSA_ASSIGN 4
  95. #define RS_ISR_PASS_LIMIT 256
  96. #define _INLINE_ inline
  97. #define FLG_MODEM_ACTIVE 1
  98. /* IPAC AUX */
  99. #define ELSA_IPAC_LINE_LED 0x40 /* Bit 6 Gelbe LED */
  100. #define ELSA_IPAC_STAT_LED 0x80 /* Bit 7 Gruene LED */
  101. #if ARCOFI_USE
  102. static struct arcofi_msg ARCOFI_XOP_F =
  103. {NULL,0,2,{0xa1,0x3f,0,0,0,0,0,0,0,0}}; /* Normal OP */
  104. static struct arcofi_msg ARCOFI_XOP_1 =
  105. {&ARCOFI_XOP_F,0,2,{0xa1,0x31,0,0,0,0,0,0,0,0}}; /* PWR UP */
  106. static struct arcofi_msg ARCOFI_SOP_F =
  107. {&ARCOFI_XOP_1,0,10,{0xa1,0x1f,0x00,0x50,0x10,0x00,0x00,0x80,0x02,0x12}};
  108. static struct arcofi_msg ARCOFI_COP_9 =
  109. {&ARCOFI_SOP_F,0,10,{0xa1,0x29,0x80,0xcb,0xe9,0x88,0x00,0xc8,0xd8,0x80}}; /* RX */
  110. static struct arcofi_msg ARCOFI_COP_8 =
  111. {&ARCOFI_COP_9,0,10,{0xa1,0x28,0x49,0x31,0x8,0x13,0x6e,0x88,0x2a,0x61}}; /* TX */
  112. static struct arcofi_msg ARCOFI_COP_7 =
  113. {&ARCOFI_COP_8,0,4,{0xa1,0x27,0x80,0x80,0,0,0,0,0,0}}; /* GZ */
  114. static struct arcofi_msg ARCOFI_COP_6 =
  115. {&ARCOFI_COP_7,0,6,{0xa1,0x26,0,0,0x82,0x7c,0,0,0,0}}; /* GRL GRH */
  116. static struct arcofi_msg ARCOFI_COP_5 =
  117. {&ARCOFI_COP_6,0,4,{0xa1,0x25,0xbb,0x4a,0,0,0,0,0,0}}; /* GTX */
  118. static struct arcofi_msg ARCOFI_VERSION =
  119. {NULL,1,2,{0xa0,0,0,0,0,0,0,0,0,0}};
  120. static struct arcofi_msg ARCOFI_XOP_0 =
  121. {NULL,0,2,{0xa1,0x30,0,0,0,0,0,0,0,0}}; /* PWR Down */
  122. static void set_arcofi(struct IsdnCardState *cs, int bc);
  123. #include "elsa_ser.c"
  124. #endif /* ARCOFI_USE */
  125. static inline u_char
  126. readreg(unsigned int ale, unsigned int adr, u_char off)
  127. {
  128. register u_char ret;
  129. byteout(ale, off);
  130. ret = bytein(adr);
  131. return (ret);
  132. }
  133. static inline void
  134. readfifo(unsigned int ale, unsigned int adr, u_char off, u_char * data, int size)
  135. {
  136. byteout(ale, off);
  137. insb(adr, data, size);
  138. }
  139. static inline void
  140. writereg(unsigned int ale, unsigned int adr, u_char off, u_char data)
  141. {
  142. byteout(ale, off);
  143. byteout(adr, data);
  144. }
  145. static inline void
  146. writefifo(unsigned int ale, unsigned int adr, u_char off, u_char * data, int size)
  147. {
  148. byteout(ale, off);
  149. outsb(adr, data, size);
  150. }
  151. /* Interface functions */
  152. static u_char
  153. ReadISAC(struct IsdnCardState *cs, u_char offset)
  154. {
  155. return (readreg(cs->hw.elsa.ale, cs->hw.elsa.isac, offset));
  156. }
  157. static void
  158. WriteISAC(struct IsdnCardState *cs, u_char offset, u_char value)
  159. {
  160. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, offset, value);
  161. }
  162. static void
  163. ReadISACfifo(struct IsdnCardState *cs, u_char * data, int size)
  164. {
  165. readfifo(cs->hw.elsa.ale, cs->hw.elsa.isac, 0, data, size);
  166. }
  167. static void
  168. WriteISACfifo(struct IsdnCardState *cs, u_char * data, int size)
  169. {
  170. writefifo(cs->hw.elsa.ale, cs->hw.elsa.isac, 0, data, size);
  171. }
  172. static u_char
  173. ReadISAC_IPAC(struct IsdnCardState *cs, u_char offset)
  174. {
  175. return (readreg(cs->hw.elsa.ale, cs->hw.elsa.isac, offset+0x80));
  176. }
  177. static void
  178. WriteISAC_IPAC(struct IsdnCardState *cs, u_char offset, u_char value)
  179. {
  180. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, offset|0x80, value);
  181. }
  182. static void
  183. ReadISACfifo_IPAC(struct IsdnCardState *cs, u_char * data, int size)
  184. {
  185. readfifo(cs->hw.elsa.ale, cs->hw.elsa.isac, 0x80, data, size);
  186. }
  187. static void
  188. WriteISACfifo_IPAC(struct IsdnCardState *cs, u_char * data, int size)
  189. {
  190. writefifo(cs->hw.elsa.ale, cs->hw.elsa.isac, 0x80, data, size);
  191. }
  192. static u_char
  193. ReadHSCX(struct IsdnCardState *cs, int hscx, u_char offset)
  194. {
  195. return (readreg(cs->hw.elsa.ale,
  196. cs->hw.elsa.hscx, offset + (hscx ? 0x40 : 0)));
  197. }
  198. static void
  199. WriteHSCX(struct IsdnCardState *cs, int hscx, u_char offset, u_char value)
  200. {
  201. writereg(cs->hw.elsa.ale,
  202. cs->hw.elsa.hscx, offset + (hscx ? 0x40 : 0), value);
  203. }
  204. static inline u_char
  205. readitac(struct IsdnCardState *cs, u_char off)
  206. {
  207. register u_char ret;
  208. byteout(cs->hw.elsa.ale, off);
  209. ret = bytein(cs->hw.elsa.itac);
  210. return (ret);
  211. }
  212. static inline void
  213. writeitac(struct IsdnCardState *cs, u_char off, u_char data)
  214. {
  215. byteout(cs->hw.elsa.ale, off);
  216. byteout(cs->hw.elsa.itac, data);
  217. }
  218. static inline int
  219. TimerRun(struct IsdnCardState *cs)
  220. {
  221. register u_char v;
  222. v = bytein(cs->hw.elsa.cfg);
  223. if ((cs->subtyp == ELSA_QS1000) || (cs->subtyp == ELSA_QS3000))
  224. return (0 == (v & ELSA_TIMER_RUN));
  225. else if (cs->subtyp == ELSA_PCC8)
  226. return (v & ELSA_TIMER_RUN_PCC8);
  227. return (v & ELSA_TIMER_RUN);
  228. }
  229. /*
  230. * fast interrupt HSCX stuff goes here
  231. */
  232. #define READHSCX(cs, nr, reg) readreg(cs->hw.elsa.ale, \
  233. cs->hw.elsa.hscx, reg + (nr ? 0x40 : 0))
  234. #define WRITEHSCX(cs, nr, reg, data) writereg(cs->hw.elsa.ale, \
  235. cs->hw.elsa.hscx, reg + (nr ? 0x40 : 0), data)
  236. #define READHSCXFIFO(cs, nr, ptr, cnt) readfifo(cs->hw.elsa.ale, \
  237. cs->hw.elsa.hscx, (nr ? 0x40 : 0), ptr, cnt)
  238. #define WRITEHSCXFIFO(cs, nr, ptr, cnt) writefifo(cs->hw.elsa.ale, \
  239. cs->hw.elsa.hscx, (nr ? 0x40 : 0), ptr, cnt)
  240. #include "hscx_irq.c"
  241. static irqreturn_t
  242. elsa_interrupt(int intno, void *dev_id, struct pt_regs *regs)
  243. {
  244. struct IsdnCardState *cs = dev_id;
  245. u_long flags;
  246. u_char val;
  247. int icnt=5;
  248. if ((cs->typ == ISDN_CTYPE_ELSA_PCMCIA) && (*cs->busy_flag == 1)) {
  249. /* The card tends to generate interrupts while being removed
  250. causing us to just crash the kernel. bad. */
  251. printk(KERN_WARNING "Elsa: card not available!\n");
  252. return IRQ_NONE;
  253. }
  254. spin_lock_irqsave(&cs->lock, flags);
  255. #if ARCOFI_USE
  256. if (cs->hw.elsa.MFlag) {
  257. val = serial_inp(cs, UART_IIR);
  258. if (!(val & UART_IIR_NO_INT)) {
  259. debugl1(cs,"IIR %02x", val);
  260. rs_interrupt_elsa(intno, cs);
  261. }
  262. }
  263. #endif
  264. val = readreg(cs->hw.elsa.ale, cs->hw.elsa.hscx, HSCX_ISTA + 0x40);
  265. Start_HSCX:
  266. if (val) {
  267. hscx_int_main(cs, val);
  268. }
  269. val = readreg(cs->hw.elsa.ale, cs->hw.elsa.isac, ISAC_ISTA);
  270. Start_ISAC:
  271. if (val) {
  272. isac_interrupt(cs, val);
  273. }
  274. val = readreg(cs->hw.elsa.ale, cs->hw.elsa.hscx, HSCX_ISTA + 0x40);
  275. if (val && icnt) {
  276. if (cs->debug & L1_DEB_HSCX)
  277. debugl1(cs, "HSCX IntStat after IntRoutine");
  278. icnt--;
  279. goto Start_HSCX;
  280. }
  281. val = readreg(cs->hw.elsa.ale, cs->hw.elsa.isac, ISAC_ISTA);
  282. if (val && icnt) {
  283. if (cs->debug & L1_DEB_ISAC)
  284. debugl1(cs, "ISAC IntStat after IntRoutine");
  285. icnt--;
  286. goto Start_ISAC;
  287. }
  288. if (!icnt)
  289. printk(KERN_WARNING"ELSA IRQ LOOP\n");
  290. writereg(cs->hw.elsa.ale, cs->hw.elsa.hscx, HSCX_MASK, 0xFF);
  291. writereg(cs->hw.elsa.ale, cs->hw.elsa.hscx, HSCX_MASK + 0x40, 0xFF);
  292. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, ISAC_MASK, 0xFF);
  293. if (cs->hw.elsa.status & ELSA_TIMER_AKTIV) {
  294. if (!TimerRun(cs)) {
  295. /* Timer Restart */
  296. byteout(cs->hw.elsa.timer, 0);
  297. cs->hw.elsa.counter++;
  298. }
  299. }
  300. #if ARCOFI_USE
  301. if (cs->hw.elsa.MFlag) {
  302. val = serial_inp(cs, UART_MCR);
  303. val ^= 0x8;
  304. serial_outp(cs, UART_MCR, val);
  305. val = serial_inp(cs, UART_MCR);
  306. val ^= 0x8;
  307. serial_outp(cs, UART_MCR, val);
  308. }
  309. #endif
  310. if (cs->hw.elsa.trig)
  311. byteout(cs->hw.elsa.trig, 0x00);
  312. writereg(cs->hw.elsa.ale, cs->hw.elsa.hscx, HSCX_MASK, 0x0);
  313. writereg(cs->hw.elsa.ale, cs->hw.elsa.hscx, HSCX_MASK + 0x40, 0x0);
  314. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, ISAC_MASK, 0x0);
  315. spin_unlock_irqrestore(&cs->lock, flags);
  316. return IRQ_HANDLED;
  317. }
  318. static irqreturn_t
  319. elsa_interrupt_ipac(int intno, void *dev_id, struct pt_regs *regs)
  320. {
  321. struct IsdnCardState *cs = dev_id;
  322. u_long flags;
  323. u_char ista,val;
  324. int icnt=5;
  325. spin_lock_irqsave(&cs->lock, flags);
  326. if (cs->subtyp == ELSA_QS1000PCI || cs->subtyp == ELSA_QS3000PCI) {
  327. val = bytein(cs->hw.elsa.cfg + 0x4c); /* PCI IRQ */
  328. if (!(val & ELSA_PCI_IRQ_MASK)) {
  329. spin_unlock_irqrestore(&cs->lock, flags);
  330. return IRQ_NONE;
  331. }
  332. }
  333. #if ARCOFI_USE
  334. if (cs->hw.elsa.MFlag) {
  335. val = serial_inp(cs, UART_IIR);
  336. if (!(val & UART_IIR_NO_INT)) {
  337. debugl1(cs,"IIR %02x", val);
  338. rs_interrupt_elsa(intno, cs);
  339. }
  340. }
  341. #endif
  342. ista = readreg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_ISTA);
  343. Start_IPAC:
  344. if (cs->debug & L1_DEB_IPAC)
  345. debugl1(cs, "IPAC ISTA %02X", ista);
  346. if (ista & 0x0f) {
  347. val = readreg(cs->hw.elsa.ale, cs->hw.elsa.hscx, HSCX_ISTA + 0x40);
  348. if (ista & 0x01)
  349. val |= 0x01;
  350. if (ista & 0x04)
  351. val |= 0x02;
  352. if (ista & 0x08)
  353. val |= 0x04;
  354. if (val)
  355. hscx_int_main(cs, val);
  356. }
  357. if (ista & 0x20) {
  358. val = 0xfe & readreg(cs->hw.elsa.ale, cs->hw.elsa.isac, ISAC_ISTA + 0x80);
  359. if (val) {
  360. isac_interrupt(cs, val);
  361. }
  362. }
  363. if (ista & 0x10) {
  364. val = 0x01;
  365. isac_interrupt(cs, val);
  366. }
  367. ista = readreg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_ISTA);
  368. if ((ista & 0x3f) && icnt) {
  369. icnt--;
  370. goto Start_IPAC;
  371. }
  372. if (!icnt)
  373. printk(KERN_WARNING "ELSA IRQ LOOP\n");
  374. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_MASK, 0xFF);
  375. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_MASK, 0xC0);
  376. spin_unlock_irqrestore(&cs->lock, flags);
  377. return IRQ_HANDLED;
  378. }
  379. static void
  380. release_io_elsa(struct IsdnCardState *cs)
  381. {
  382. int bytecnt = 8;
  383. del_timer(&cs->hw.elsa.tl);
  384. #if ARCOFI_USE
  385. clear_arcofi(cs);
  386. #endif
  387. if (cs->hw.elsa.ctrl)
  388. byteout(cs->hw.elsa.ctrl, 0); /* LEDs Out */
  389. if (cs->subtyp == ELSA_QS1000PCI) {
  390. byteout(cs->hw.elsa.cfg + 0x4c, 0x01); /* disable IRQ */
  391. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_ATX, 0xff);
  392. bytecnt = 2;
  393. release_region(cs->hw.elsa.cfg, 0x80);
  394. }
  395. if (cs->subtyp == ELSA_QS3000PCI) {
  396. byteout(cs->hw.elsa.cfg + 0x4c, 0x03); /* disable ELSA PCI IRQ */
  397. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_ATX, 0xff);
  398. release_region(cs->hw.elsa.cfg, 0x80);
  399. }
  400. if (cs->subtyp == ELSA_PCMCIA_IPAC) {
  401. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_ATX, 0xff);
  402. }
  403. if ((cs->subtyp == ELSA_PCFPRO) ||
  404. (cs->subtyp == ELSA_QS3000) ||
  405. (cs->subtyp == ELSA_PCF) ||
  406. (cs->subtyp == ELSA_QS3000PCI)) {
  407. bytecnt = 16;
  408. #if ARCOFI_USE
  409. release_modem(cs);
  410. #endif
  411. }
  412. if (cs->hw.elsa.base)
  413. release_region(cs->hw.elsa.base, bytecnt);
  414. }
  415. static void
  416. reset_elsa(struct IsdnCardState *cs)
  417. {
  418. if (cs->hw.elsa.timer) {
  419. /* Wait 1 Timer */
  420. byteout(cs->hw.elsa.timer, 0);
  421. while (TimerRun(cs));
  422. cs->hw.elsa.ctrl_reg |= 0x50;
  423. cs->hw.elsa.ctrl_reg &= ~ELSA_ISDN_RESET; /* Reset On */
  424. byteout(cs->hw.elsa.ctrl, cs->hw.elsa.ctrl_reg);
  425. /* Wait 1 Timer */
  426. byteout(cs->hw.elsa.timer, 0);
  427. while (TimerRun(cs));
  428. cs->hw.elsa.ctrl_reg |= ELSA_ISDN_RESET; /* Reset Off */
  429. byteout(cs->hw.elsa.ctrl, cs->hw.elsa.ctrl_reg);
  430. /* Wait 1 Timer */
  431. byteout(cs->hw.elsa.timer, 0);
  432. while (TimerRun(cs));
  433. if (cs->hw.elsa.trig)
  434. byteout(cs->hw.elsa.trig, 0xff);
  435. }
  436. if ((cs->subtyp == ELSA_QS1000PCI) || (cs->subtyp == ELSA_QS3000PCI) || (cs->subtyp == ELSA_PCMCIA_IPAC)) {
  437. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_POTA2, 0x20);
  438. mdelay(10);
  439. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_POTA2, 0x00);
  440. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_MASK, 0xc0);
  441. mdelay(10);
  442. if (cs->subtyp != ELSA_PCMCIA_IPAC) {
  443. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_ACFG, 0x0);
  444. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_AOE, 0x3c);
  445. } else {
  446. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_PCFG, 0x10);
  447. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_ACFG, 0x4);
  448. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_AOE, 0xf8);
  449. }
  450. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_ATX, 0xff);
  451. if (cs->subtyp == ELSA_QS1000PCI)
  452. byteout(cs->hw.elsa.cfg + 0x4c, 0x41); /* enable ELSA PCI IRQ */
  453. else if (cs->subtyp == ELSA_QS3000PCI)
  454. byteout(cs->hw.elsa.cfg + 0x4c, 0x43); /* enable ELSA PCI IRQ */
  455. }
  456. }
  457. #if ARCOFI_USE
  458. static void
  459. set_arcofi(struct IsdnCardState *cs, int bc) {
  460. cs->dc.isac.arcofi_bc = bc;
  461. arcofi_fsm(cs, ARCOFI_START, &ARCOFI_COP_5);
  462. interruptible_sleep_on(&cs->dc.isac.arcofi_wait);
  463. }
  464. static int
  465. check_arcofi(struct IsdnCardState *cs)
  466. {
  467. int arcofi_present = 0;
  468. char tmp[40];
  469. char *t;
  470. u_char *p;
  471. if (!cs->dc.isac.mon_tx)
  472. if (!(cs->dc.isac.mon_tx=kmalloc(MAX_MON_FRAME, GFP_ATOMIC))) {
  473. if (cs->debug & L1_DEB_WARN)
  474. debugl1(cs, "ISAC MON TX out of buffers!");
  475. return(0);
  476. }
  477. cs->dc.isac.arcofi_bc = 0;
  478. arcofi_fsm(cs, ARCOFI_START, &ARCOFI_VERSION);
  479. interruptible_sleep_on(&cs->dc.isac.arcofi_wait);
  480. if (!test_and_clear_bit(FLG_ARCOFI_ERROR, &cs->HW_Flags)) {
  481. debugl1(cs, "Arcofi response received %d bytes", cs->dc.isac.mon_rxp);
  482. p = cs->dc.isac.mon_rx;
  483. t = tmp;
  484. t += sprintf(tmp, "Arcofi data");
  485. QuickHex(t, p, cs->dc.isac.mon_rxp);
  486. debugl1(cs, tmp);
  487. if ((cs->dc.isac.mon_rxp == 2) && (cs->dc.isac.mon_rx[0] == 0xa0)) {
  488. switch(cs->dc.isac.mon_rx[1]) {
  489. case 0x80:
  490. debugl1(cs, "Arcofi 2160 detected");
  491. arcofi_present = 1;
  492. break;
  493. case 0x82:
  494. debugl1(cs, "Arcofi 2165 detected");
  495. arcofi_present = 2;
  496. break;
  497. case 0x84:
  498. debugl1(cs, "Arcofi 2163 detected");
  499. arcofi_present = 3;
  500. break;
  501. default:
  502. debugl1(cs, "unknown Arcofi response");
  503. break;
  504. }
  505. } else
  506. debugl1(cs, "undefined Monitor response");
  507. cs->dc.isac.mon_rxp = 0;
  508. } else if (cs->dc.isac.mon_tx) {
  509. debugl1(cs, "Arcofi not detected");
  510. }
  511. if (arcofi_present) {
  512. if (cs->subtyp==ELSA_QS1000) {
  513. cs->subtyp = ELSA_QS3000;
  514. printk(KERN_INFO
  515. "Elsa: %s detected modem at 0x%lx\n",
  516. Elsa_Types[cs->subtyp],
  517. cs->hw.elsa.base+8);
  518. release_region(cs->hw.elsa.base, 8);
  519. if (!request_region(cs->hw.elsa.base, 16, "elsa isdn modem")) {
  520. printk(KERN_WARNING
  521. "HiSax: %s config port %lx-%lx already in use\n",
  522. Elsa_Types[cs->subtyp],
  523. cs->hw.elsa.base + 8,
  524. cs->hw.elsa.base + 16);
  525. }
  526. } else if (cs->subtyp==ELSA_PCC16) {
  527. cs->subtyp = ELSA_PCF;
  528. printk(KERN_INFO
  529. "Elsa: %s detected modem at 0x%lx\n",
  530. Elsa_Types[cs->subtyp],
  531. cs->hw.elsa.base+8);
  532. release_region(cs->hw.elsa.base, 8);
  533. if (!request_region(cs->hw.elsa.base, 16, "elsa isdn modem")) {
  534. printk(KERN_WARNING
  535. "HiSax: %s config port %lx-%lx already in use\n",
  536. Elsa_Types[cs->subtyp],
  537. cs->hw.elsa.base + 8,
  538. cs->hw.elsa.base + 16);
  539. }
  540. } else
  541. printk(KERN_INFO
  542. "Elsa: %s detected modem at 0x%lx\n",
  543. Elsa_Types[cs->subtyp],
  544. cs->hw.elsa.base+8);
  545. arcofi_fsm(cs, ARCOFI_START, &ARCOFI_XOP_0);
  546. interruptible_sleep_on(&cs->dc.isac.arcofi_wait);
  547. return(1);
  548. }
  549. return(0);
  550. }
  551. #endif /* ARCOFI_USE */
  552. static void
  553. elsa_led_handler(struct IsdnCardState *cs)
  554. {
  555. int blink = 0;
  556. if (cs->subtyp == ELSA_PCMCIA || cs->subtyp == ELSA_PCMCIA_IPAC)
  557. return;
  558. del_timer(&cs->hw.elsa.tl);
  559. if (cs->hw.elsa.status & ELSA_ASSIGN)
  560. cs->hw.elsa.ctrl_reg |= ELSA_STAT_LED;
  561. else if (cs->hw.elsa.status & ELSA_BAD_PWR)
  562. cs->hw.elsa.ctrl_reg &= ~ELSA_STAT_LED;
  563. else {
  564. cs->hw.elsa.ctrl_reg ^= ELSA_STAT_LED;
  565. blink = 250;
  566. }
  567. if (cs->hw.elsa.status & 0xf000)
  568. cs->hw.elsa.ctrl_reg |= ELSA_LINE_LED;
  569. else if (cs->hw.elsa.status & 0x0f00) {
  570. cs->hw.elsa.ctrl_reg ^= ELSA_LINE_LED;
  571. blink = 500;
  572. } else
  573. cs->hw.elsa.ctrl_reg &= ~ELSA_LINE_LED;
  574. if ((cs->subtyp == ELSA_QS1000PCI) ||
  575. (cs->subtyp == ELSA_QS3000PCI)) {
  576. u_char led = 0xff;
  577. if (cs->hw.elsa.ctrl_reg & ELSA_LINE_LED)
  578. led ^= ELSA_IPAC_LINE_LED;
  579. if (cs->hw.elsa.ctrl_reg & ELSA_STAT_LED)
  580. led ^= ELSA_IPAC_STAT_LED;
  581. writereg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_ATX, led);
  582. } else
  583. byteout(cs->hw.elsa.ctrl, cs->hw.elsa.ctrl_reg);
  584. if (blink) {
  585. init_timer(&cs->hw.elsa.tl);
  586. cs->hw.elsa.tl.expires = jiffies + ((blink * HZ) / 1000);
  587. add_timer(&cs->hw.elsa.tl);
  588. }
  589. }
  590. static int
  591. Elsa_card_msg(struct IsdnCardState *cs, int mt, void *arg)
  592. {
  593. int ret = 0;
  594. u_long flags;
  595. switch (mt) {
  596. case CARD_RESET:
  597. spin_lock_irqsave(&cs->lock, flags);
  598. reset_elsa(cs);
  599. spin_unlock_irqrestore(&cs->lock, flags);
  600. return(0);
  601. case CARD_RELEASE:
  602. release_io_elsa(cs);
  603. return(0);
  604. case CARD_INIT:
  605. spin_lock_irqsave(&cs->lock, flags);
  606. cs->debug |= L1_DEB_IPAC;
  607. reset_elsa(cs);
  608. inithscxisac(cs, 1);
  609. if ((cs->subtyp == ELSA_QS1000) ||
  610. (cs->subtyp == ELSA_QS3000))
  611. {
  612. byteout(cs->hw.elsa.timer, 0);
  613. }
  614. if (cs->hw.elsa.trig)
  615. byteout(cs->hw.elsa.trig, 0xff);
  616. inithscxisac(cs, 2);
  617. spin_unlock_irqrestore(&cs->lock, flags);
  618. return(0);
  619. case CARD_TEST:
  620. if ((cs->subtyp == ELSA_PCMCIA) ||
  621. (cs->subtyp == ELSA_PCMCIA_IPAC) ||
  622. (cs->subtyp == ELSA_QS1000PCI)) {
  623. return(0);
  624. } else if (cs->subtyp == ELSA_QS3000PCI) {
  625. ret = 0;
  626. } else {
  627. spin_lock_irqsave(&cs->lock, flags);
  628. cs->hw.elsa.counter = 0;
  629. cs->hw.elsa.ctrl_reg |= ELSA_ENA_TIMER_INT;
  630. cs->hw.elsa.status |= ELSA_TIMER_AKTIV;
  631. byteout(cs->hw.elsa.ctrl, cs->hw.elsa.ctrl_reg);
  632. byteout(cs->hw.elsa.timer, 0);
  633. spin_unlock_irqrestore(&cs->lock, flags);
  634. msleep(110);
  635. spin_lock_irqsave(&cs->lock, flags);
  636. cs->hw.elsa.ctrl_reg &= ~ELSA_ENA_TIMER_INT;
  637. byteout(cs->hw.elsa.ctrl, cs->hw.elsa.ctrl_reg);
  638. cs->hw.elsa.status &= ~ELSA_TIMER_AKTIV;
  639. spin_unlock_irqrestore(&cs->lock, flags);
  640. printk(KERN_INFO "Elsa: %d timer tics in 110 msek\n",
  641. cs->hw.elsa.counter);
  642. if ((cs->hw.elsa.counter > 10) &&
  643. (cs->hw.elsa.counter < 16)) {
  644. printk(KERN_INFO "Elsa: timer and irq OK\n");
  645. ret = 0;
  646. } else {
  647. printk(KERN_WARNING
  648. "Elsa: timer tic problem (%d/12) maybe an IRQ(%d) conflict\n",
  649. cs->hw.elsa.counter, cs->irq);
  650. ret = 1;
  651. }
  652. }
  653. #if ARCOFI_USE
  654. if (check_arcofi(cs)) {
  655. init_modem(cs);
  656. }
  657. #endif
  658. elsa_led_handler(cs);
  659. return(ret);
  660. case (MDL_REMOVE | REQUEST):
  661. cs->hw.elsa.status &= 0;
  662. break;
  663. case (MDL_ASSIGN | REQUEST):
  664. cs->hw.elsa.status |= ELSA_ASSIGN;
  665. break;
  666. case MDL_INFO_SETUP:
  667. if ((long) arg)
  668. cs->hw.elsa.status |= 0x0200;
  669. else
  670. cs->hw.elsa.status |= 0x0100;
  671. break;
  672. case MDL_INFO_CONN:
  673. if ((long) arg)
  674. cs->hw.elsa.status |= 0x2000;
  675. else
  676. cs->hw.elsa.status |= 0x1000;
  677. break;
  678. case MDL_INFO_REL:
  679. if ((long) arg) {
  680. cs->hw.elsa.status &= ~0x2000;
  681. cs->hw.elsa.status &= ~0x0200;
  682. } else {
  683. cs->hw.elsa.status &= ~0x1000;
  684. cs->hw.elsa.status &= ~0x0100;
  685. }
  686. break;
  687. #if ARCOFI_USE
  688. case CARD_AUX_IND:
  689. if (cs->hw.elsa.MFlag) {
  690. int len;
  691. u_char *msg;
  692. if (!arg)
  693. return(0);
  694. msg = arg;
  695. len = *msg;
  696. msg++;
  697. modem_write_cmd(cs, msg, len);
  698. }
  699. break;
  700. #endif
  701. }
  702. if (cs->typ == ISDN_CTYPE_ELSA) {
  703. int pwr = bytein(cs->hw.elsa.ale);
  704. if (pwr & 0x08)
  705. cs->hw.elsa.status |= ELSA_BAD_PWR;
  706. else
  707. cs->hw.elsa.status &= ~ELSA_BAD_PWR;
  708. }
  709. elsa_led_handler(cs);
  710. return(ret);
  711. }
  712. static unsigned char
  713. probe_elsa_adr(unsigned int adr, int typ)
  714. {
  715. int i, in1, in2, p16_1 = 0, p16_2 = 0, p8_1 = 0, p8_2 = 0, pc_1 = 0,
  716. pc_2 = 0, pfp_1 = 0, pfp_2 = 0;
  717. /* In case of the elsa pcmcia card, this region is in use,
  718. reserved for us by the card manager. So we do not check it
  719. here, it would fail. */
  720. if (typ != ISDN_CTYPE_ELSA_PCMCIA) {
  721. if (request_region(adr, 8, "elsa card")) {
  722. release_region(adr, 8);
  723. } else {
  724. printk(KERN_WARNING
  725. "Elsa: Probing Port 0x%x: already in use\n", adr);
  726. return (0);
  727. }
  728. }
  729. for (i = 0; i < 16; i++) {
  730. in1 = inb(adr + ELSA_CONFIG); /* 'toggelt' bei */
  731. in2 = inb(adr + ELSA_CONFIG); /* jedem Zugriff */
  732. p16_1 += 0x04 & in1;
  733. p16_2 += 0x04 & in2;
  734. p8_1 += 0x02 & in1;
  735. p8_2 += 0x02 & in2;
  736. pc_1 += 0x01 & in1;
  737. pc_2 += 0x01 & in2;
  738. pfp_1 += 0x40 & in1;
  739. pfp_2 += 0x40 & in2;
  740. }
  741. printk(KERN_INFO "Elsa: Probing IO 0x%x", adr);
  742. if (65 == ++p16_1 * ++p16_2) {
  743. printk(" PCC-16/PCF found\n");
  744. return (ELSA_PCC16);
  745. } else if (1025 == ++pfp_1 * ++pfp_2) {
  746. printk(" PCF-Pro found\n");
  747. return (ELSA_PCFPRO);
  748. } else if (33 == ++p8_1 * ++p8_2) {
  749. printk(" PCC8 found\n");
  750. return (ELSA_PCC8);
  751. } else if (17 == ++pc_1 * ++pc_2) {
  752. printk(" PC found\n");
  753. return (ELSA_PC);
  754. } else {
  755. printk(" failed\n");
  756. return (0);
  757. }
  758. }
  759. static unsigned int
  760. probe_elsa(struct IsdnCardState *cs)
  761. {
  762. int i;
  763. unsigned int CARD_portlist[] =
  764. {0x160, 0x170, 0x260, 0x360, 0};
  765. for (i = 0; CARD_portlist[i]; i++) {
  766. if ((cs->subtyp = probe_elsa_adr(CARD_portlist[i], cs->typ)))
  767. break;
  768. }
  769. return (CARD_portlist[i]);
  770. }
  771. static struct pci_dev *dev_qs1000 __devinitdata = NULL;
  772. static struct pci_dev *dev_qs3000 __devinitdata = NULL;
  773. #ifdef __ISAPNP__
  774. static struct isapnp_device_id elsa_ids[] __devinitdata = {
  775. { ISAPNP_VENDOR('E', 'L', 'S'), ISAPNP_FUNCTION(0x0133),
  776. ISAPNP_VENDOR('E', 'L', 'S'), ISAPNP_FUNCTION(0x0133),
  777. (unsigned long) "Elsa QS1000" },
  778. { ISAPNP_VENDOR('E', 'L', 'S'), ISAPNP_FUNCTION(0x0134),
  779. ISAPNP_VENDOR('E', 'L', 'S'), ISAPNP_FUNCTION(0x0134),
  780. (unsigned long) "Elsa QS3000" },
  781. { 0, }
  782. };
  783. static struct isapnp_device_id *ipid __devinitdata = &elsa_ids[0];
  784. static struct pnp_card *pnp_c __devinitdata = NULL;
  785. #endif
  786. int __devinit
  787. setup_elsa(struct IsdnCard *card)
  788. {
  789. int bytecnt;
  790. u_char val;
  791. struct IsdnCardState *cs = card->cs;
  792. char tmp[64];
  793. strcpy(tmp, Elsa_revision);
  794. printk(KERN_INFO "HiSax: Elsa driver Rev. %s\n", HiSax_getrev(tmp));
  795. cs->hw.elsa.ctrl_reg = 0;
  796. cs->hw.elsa.status = 0;
  797. cs->hw.elsa.MFlag = 0;
  798. cs->subtyp = 0;
  799. if (cs->typ == ISDN_CTYPE_ELSA) {
  800. cs->hw.elsa.base = card->para[0];
  801. printk(KERN_INFO "Elsa: Microlink IO probing\n");
  802. if (cs->hw.elsa.base) {
  803. if (!(cs->subtyp = probe_elsa_adr(cs->hw.elsa.base,
  804. cs->typ))) {
  805. printk(KERN_WARNING
  806. "Elsa: no Elsa Microlink at %#lx\n",
  807. cs->hw.elsa.base);
  808. return (0);
  809. }
  810. } else
  811. cs->hw.elsa.base = probe_elsa(cs);
  812. if (cs->hw.elsa.base) {
  813. cs->hw.elsa.cfg = cs->hw.elsa.base + ELSA_CONFIG;
  814. cs->hw.elsa.ctrl = cs->hw.elsa.base + ELSA_CONTROL;
  815. cs->hw.elsa.ale = cs->hw.elsa.base + ELSA_ALE;
  816. cs->hw.elsa.isac = cs->hw.elsa.base + ELSA_ISAC;
  817. cs->hw.elsa.itac = cs->hw.elsa.base + ELSA_ITAC;
  818. cs->hw.elsa.hscx = cs->hw.elsa.base + ELSA_HSCX;
  819. cs->hw.elsa.trig = cs->hw.elsa.base + ELSA_TRIG_IRQ;
  820. cs->hw.elsa.timer = cs->hw.elsa.base + ELSA_START_TIMER;
  821. val = bytein(cs->hw.elsa.cfg);
  822. if (cs->subtyp == ELSA_PC) {
  823. const u_char CARD_IrqTab[8] =
  824. {7, 3, 5, 9, 0, 0, 0, 0};
  825. cs->irq = CARD_IrqTab[(val & ELSA_IRQ_IDX_PC) >> 2];
  826. } else if (cs->subtyp == ELSA_PCC8) {
  827. const u_char CARD_IrqTab[8] =
  828. {7, 3, 5, 9, 0, 0, 0, 0};
  829. cs->irq = CARD_IrqTab[(val & ELSA_IRQ_IDX_PCC8) >> 4];
  830. } else {
  831. const u_char CARD_IrqTab[8] =
  832. {15, 10, 15, 3, 11, 5, 11, 9};
  833. cs->irq = CARD_IrqTab[(val & ELSA_IRQ_IDX) >> 3];
  834. }
  835. val = bytein(cs->hw.elsa.ale) & ELSA_HW_RELEASE;
  836. if (val < 3)
  837. val |= 8;
  838. val += 'A' - 3;
  839. if (val == 'B' || val == 'C')
  840. val ^= 1;
  841. if ((cs->subtyp == ELSA_PCFPRO) && (val = 'G'))
  842. val = 'C';
  843. printk(KERN_INFO
  844. "Elsa: %s found at %#lx Rev.:%c IRQ %d\n",
  845. Elsa_Types[cs->subtyp],
  846. cs->hw.elsa.base,
  847. val, cs->irq);
  848. val = bytein(cs->hw.elsa.ale) & ELSA_S0_POWER_BAD;
  849. if (val) {
  850. printk(KERN_WARNING
  851. "Elsa: Microlink S0 bus power bad\n");
  852. cs->hw.elsa.status |= ELSA_BAD_PWR;
  853. }
  854. } else {
  855. printk(KERN_WARNING
  856. "No Elsa Microlink found\n");
  857. return (0);
  858. }
  859. } else if (cs->typ == ISDN_CTYPE_ELSA_PNP) {
  860. #ifdef __ISAPNP__
  861. if (!card->para[1] && isapnp_present()) {
  862. struct pnp_dev *pnp_d;
  863. while(ipid->card_vendor) {
  864. if ((pnp_c = pnp_find_card(ipid->card_vendor,
  865. ipid->card_device, pnp_c))) {
  866. pnp_d = NULL;
  867. if ((pnp_d = pnp_find_dev(pnp_c,
  868. ipid->vendor, ipid->function, pnp_d))) {
  869. int err;
  870. printk(KERN_INFO "HiSax: %s detected\n",
  871. (char *)ipid->driver_data);
  872. pnp_disable_dev(pnp_d);
  873. err = pnp_activate_dev(pnp_d);
  874. if (err<0) {
  875. printk(KERN_WARNING "%s: pnp_activate_dev ret(%d)\n",
  876. __FUNCTION__, err);
  877. return(0);
  878. }
  879. card->para[1] = pnp_port_start(pnp_d, 0);
  880. card->para[0] = pnp_irq(pnp_d, 0);
  881. if (!card->para[0] || !card->para[1]) {
  882. printk(KERN_ERR "Elsa PnP:some resources are missing %ld/%lx\n",
  883. card->para[0], card->para[1]);
  884. pnp_disable_dev(pnp_d);
  885. return(0);
  886. }
  887. if (ipid->function == ISAPNP_FUNCTION(0x133))
  888. cs->subtyp = ELSA_QS1000;
  889. else
  890. cs->subtyp = ELSA_QS3000;
  891. break;
  892. } else {
  893. printk(KERN_ERR "Elsa PnP: PnP error card found, no device\n");
  894. return(0);
  895. }
  896. }
  897. ipid++;
  898. pnp_c=NULL;
  899. }
  900. if (!ipid->card_vendor) {
  901. printk(KERN_INFO "Elsa PnP: no ISAPnP card found\n");
  902. return(0);
  903. }
  904. }
  905. #endif
  906. if (card->para[1] && card->para[0]) {
  907. cs->hw.elsa.base = card->para[1];
  908. cs->irq = card->para[0];
  909. if (!cs->subtyp)
  910. cs->subtyp = ELSA_QS1000;
  911. } else {
  912. printk(KERN_ERR "Elsa PnP: no parameter\n");
  913. }
  914. cs->hw.elsa.cfg = cs->hw.elsa.base + ELSA_CONFIG;
  915. cs->hw.elsa.ale = cs->hw.elsa.base + ELSA_ALE;
  916. cs->hw.elsa.isac = cs->hw.elsa.base + ELSA_ISAC;
  917. cs->hw.elsa.hscx = cs->hw.elsa.base + ELSA_HSCX;
  918. cs->hw.elsa.trig = cs->hw.elsa.base + ELSA_TRIG_IRQ;
  919. cs->hw.elsa.timer = cs->hw.elsa.base + ELSA_START_TIMER;
  920. cs->hw.elsa.ctrl = cs->hw.elsa.base + ELSA_CONTROL;
  921. printk(KERN_INFO
  922. "Elsa: %s defined at %#lx IRQ %d\n",
  923. Elsa_Types[cs->subtyp],
  924. cs->hw.elsa.base,
  925. cs->irq);
  926. } else if (cs->typ == ISDN_CTYPE_ELSA_PCMCIA) {
  927. cs->hw.elsa.base = card->para[1];
  928. cs->irq = card->para[0];
  929. val = readreg(cs->hw.elsa.base + 0, cs->hw.elsa.base + 2, IPAC_ID);
  930. if ((val == 1) || (val == 2)) { /* IPAC version 1.1/1.2 */
  931. cs->subtyp = ELSA_PCMCIA_IPAC;
  932. cs->hw.elsa.ale = cs->hw.elsa.base + 0;
  933. cs->hw.elsa.isac = cs->hw.elsa.base + 2;
  934. cs->hw.elsa.hscx = cs->hw.elsa.base + 2;
  935. test_and_set_bit(HW_IPAC, &cs->HW_Flags);
  936. } else {
  937. cs->subtyp = ELSA_PCMCIA;
  938. cs->hw.elsa.ale = cs->hw.elsa.base + ELSA_ALE_PCM;
  939. cs->hw.elsa.isac = cs->hw.elsa.base + ELSA_ISAC_PCM;
  940. cs->hw.elsa.hscx = cs->hw.elsa.base + ELSA_HSCX;
  941. }
  942. cs->hw.elsa.timer = 0;
  943. cs->hw.elsa.trig = 0;
  944. cs->hw.elsa.ctrl = 0;
  945. cs->irq_flags |= SA_SHIRQ;
  946. printk(KERN_INFO
  947. "Elsa: %s defined at %#lx IRQ %d\n",
  948. Elsa_Types[cs->subtyp],
  949. cs->hw.elsa.base,
  950. cs->irq);
  951. } else if (cs->typ == ISDN_CTYPE_ELSA_PCI) {
  952. #ifdef CONFIG_PCI
  953. cs->subtyp = 0;
  954. if ((dev_qs1000 = pci_find_device(PCI_VENDOR_ID_ELSA,
  955. PCI_DEVICE_ID_ELSA_MICROLINK, dev_qs1000))) {
  956. if (pci_enable_device(dev_qs1000))
  957. return(0);
  958. cs->subtyp = ELSA_QS1000PCI;
  959. cs->irq = dev_qs1000->irq;
  960. cs->hw.elsa.cfg = pci_resource_start(dev_qs1000, 1);
  961. cs->hw.elsa.base = pci_resource_start(dev_qs1000, 3);
  962. } else if ((dev_qs3000 = pci_find_device(PCI_VENDOR_ID_ELSA,
  963. PCI_DEVICE_ID_ELSA_QS3000, dev_qs3000))) {
  964. if (pci_enable_device(dev_qs3000))
  965. return(0);
  966. cs->subtyp = ELSA_QS3000PCI;
  967. cs->irq = dev_qs3000->irq;
  968. cs->hw.elsa.cfg = pci_resource_start(dev_qs3000, 1);
  969. cs->hw.elsa.base = pci_resource_start(dev_qs3000, 3);
  970. } else {
  971. printk(KERN_WARNING "Elsa: No PCI card found\n");
  972. return(0);
  973. }
  974. if (!cs->irq) {
  975. printk(KERN_WARNING "Elsa: No IRQ for PCI card found\n");
  976. return(0);
  977. }
  978. if (!(cs->hw.elsa.base && cs->hw.elsa.cfg)) {
  979. printk(KERN_WARNING "Elsa: No IO-Adr for PCI card found\n");
  980. return(0);
  981. }
  982. if ((cs->hw.elsa.cfg & 0xff) || (cs->hw.elsa.base & 0xf)) {
  983. printk(KERN_WARNING "Elsa: You may have a wrong PCI bios\n");
  984. printk(KERN_WARNING "Elsa: If your system hangs now, read\n");
  985. printk(KERN_WARNING "Elsa: Documentation/isdn/README.HiSax\n");
  986. }
  987. cs->hw.elsa.ale = cs->hw.elsa.base;
  988. cs->hw.elsa.isac = cs->hw.elsa.base +1;
  989. cs->hw.elsa.hscx = cs->hw.elsa.base +1;
  990. test_and_set_bit(HW_IPAC, &cs->HW_Flags);
  991. cs->hw.elsa.timer = 0;
  992. cs->hw.elsa.trig = 0;
  993. cs->irq_flags |= SA_SHIRQ;
  994. printk(KERN_INFO
  995. "Elsa: %s defined at %#lx/0x%x IRQ %d\n",
  996. Elsa_Types[cs->subtyp],
  997. cs->hw.elsa.base,
  998. cs->hw.elsa.cfg,
  999. cs->irq);
  1000. #else
  1001. printk(KERN_WARNING "Elsa: Elsa PCI and NO_PCI_BIOS\n");
  1002. printk(KERN_WARNING "Elsa: unable to config Elsa PCI\n");
  1003. return (0);
  1004. #endif /* CONFIG_PCI */
  1005. } else
  1006. return (0);
  1007. switch (cs->subtyp) {
  1008. case ELSA_PC:
  1009. case ELSA_PCC8:
  1010. case ELSA_PCC16:
  1011. case ELSA_QS1000:
  1012. case ELSA_PCMCIA:
  1013. case ELSA_PCMCIA_IPAC:
  1014. bytecnt = 8;
  1015. break;
  1016. case ELSA_PCFPRO:
  1017. case ELSA_PCF:
  1018. case ELSA_QS3000:
  1019. case ELSA_QS3000PCI:
  1020. bytecnt = 16;
  1021. break;
  1022. case ELSA_QS1000PCI:
  1023. bytecnt = 2;
  1024. break;
  1025. default:
  1026. printk(KERN_WARNING
  1027. "Unknown ELSA subtype %d\n", cs->subtyp);
  1028. return (0);
  1029. }
  1030. /* In case of the elsa pcmcia card, this region is in use,
  1031. reserved for us by the card manager. So we do not check it
  1032. here, it would fail. */
  1033. if (cs->typ != ISDN_CTYPE_ELSA_PCMCIA && !request_region(cs->hw.elsa.base, bytecnt, "elsa isdn")) {
  1034. printk(KERN_WARNING
  1035. "HiSax: %s config port %#lx-%#lx already in use\n",
  1036. CardType[card->typ],
  1037. cs->hw.elsa.base,
  1038. cs->hw.elsa.base + bytecnt);
  1039. return (0);
  1040. }
  1041. if ((cs->subtyp == ELSA_QS1000PCI) || (cs->subtyp == ELSA_QS3000PCI)) {
  1042. if (!request_region(cs->hw.elsa.cfg, 0x80, "elsa isdn pci")) {
  1043. printk(KERN_WARNING
  1044. "HiSax: %s pci port %x-%x already in use\n",
  1045. CardType[card->typ],
  1046. cs->hw.elsa.cfg,
  1047. cs->hw.elsa.cfg + 0x80);
  1048. release_region(cs->hw.elsa.base, bytecnt);
  1049. return (0);
  1050. }
  1051. }
  1052. #if ARCOFI_USE
  1053. init_arcofi(cs);
  1054. #endif
  1055. setup_isac(cs);
  1056. cs->hw.elsa.tl.function = (void *) elsa_led_handler;
  1057. cs->hw.elsa.tl.data = (long) cs;
  1058. init_timer(&cs->hw.elsa.tl);
  1059. /* Teste Timer */
  1060. if (cs->hw.elsa.timer) {
  1061. byteout(cs->hw.elsa.trig, 0xff);
  1062. byteout(cs->hw.elsa.timer, 0);
  1063. if (!TimerRun(cs)) {
  1064. byteout(cs->hw.elsa.timer, 0); /* 2. Versuch */
  1065. if (!TimerRun(cs)) {
  1066. printk(KERN_WARNING
  1067. "Elsa: timer do not start\n");
  1068. release_io_elsa(cs);
  1069. return (0);
  1070. }
  1071. }
  1072. HZDELAY((HZ/100) + 1); /* wait >=10 ms */
  1073. if (TimerRun(cs)) {
  1074. printk(KERN_WARNING "Elsa: timer do not run down\n");
  1075. release_io_elsa(cs);
  1076. return (0);
  1077. }
  1078. printk(KERN_INFO "Elsa: timer OK; resetting card\n");
  1079. }
  1080. cs->BC_Read_Reg = &ReadHSCX;
  1081. cs->BC_Write_Reg = &WriteHSCX;
  1082. cs->BC_Send_Data = &hscx_fill_fifo;
  1083. cs->cardmsg = &Elsa_card_msg;
  1084. if ((cs->subtyp == ELSA_QS1000PCI) || (cs->subtyp == ELSA_QS3000PCI) || (cs->subtyp == ELSA_PCMCIA_IPAC)) {
  1085. cs->readisac = &ReadISAC_IPAC;
  1086. cs->writeisac = &WriteISAC_IPAC;
  1087. cs->readisacfifo = &ReadISACfifo_IPAC;
  1088. cs->writeisacfifo = &WriteISACfifo_IPAC;
  1089. cs->irq_func = &elsa_interrupt_ipac;
  1090. val = readreg(cs->hw.elsa.ale, cs->hw.elsa.isac, IPAC_ID);
  1091. printk(KERN_INFO "Elsa: IPAC version %x\n", val);
  1092. } else {
  1093. cs->readisac = &ReadISAC;
  1094. cs->writeisac = &WriteISAC;
  1095. cs->readisacfifo = &ReadISACfifo;
  1096. cs->writeisacfifo = &WriteISACfifo;
  1097. cs->irq_func = &elsa_interrupt;
  1098. ISACVersion(cs, "Elsa:");
  1099. if (HscxVersion(cs, "Elsa:")) {
  1100. printk(KERN_WARNING
  1101. "Elsa: wrong HSCX versions check IO address\n");
  1102. release_io_elsa(cs);
  1103. return (0);
  1104. }
  1105. }
  1106. if (cs->subtyp == ELSA_PC) {
  1107. val = readitac(cs, ITAC_SYS);
  1108. printk(KERN_INFO "Elsa: ITAC version %s\n", ITACVer[val & 7]);
  1109. writeitac(cs, ITAC_ISEN, 0);
  1110. writeitac(cs, ITAC_RFIE, 0);
  1111. writeitac(cs, ITAC_XFIE, 0);
  1112. writeitac(cs, ITAC_SCIE, 0);
  1113. writeitac(cs, ITAC_STIE, 0);
  1114. }
  1115. return (1);
  1116. }