moxa.c 61 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*****************************************************************************/
  3. /*
  4. * moxa.c -- MOXA Intellio family multiport serial driver.
  5. *
  6. * Copyright (C) 1999-2000 Moxa Technologies ([email protected]).
  7. * Copyright (c) 2007 Jiri Slaby <[email protected]>
  8. *
  9. * This code is loosely based on the Linux serial driver, written by
  10. * Linus Torvalds, Theodore T'so and others.
  11. */
  12. /*
  13. * MOXA Intellio Series Driver
  14. * for : LINUX
  15. * date : 1999/1/7
  16. * version : 5.1
  17. */
  18. #include <linux/module.h>
  19. #include <linux/types.h>
  20. #include <linux/mm.h>
  21. #include <linux/ioport.h>
  22. #include <linux/errno.h>
  23. #include <linux/firmware.h>
  24. #include <linux/signal.h>
  25. #include <linux/sched.h>
  26. #include <linux/timer.h>
  27. #include <linux/interrupt.h>
  28. #include <linux/tty.h>
  29. #include <linux/tty_flip.h>
  30. #include <linux/major.h>
  31. #include <linux/string.h>
  32. #include <linux/fcntl.h>
  33. #include <linux/ptrace.h>
  34. #include <linux/serial.h>
  35. #include <linux/tty_driver.h>
  36. #include <linux/delay.h>
  37. #include <linux/pci.h>
  38. #include <linux/init.h>
  39. #include <linux/bitops.h>
  40. #include <linux/slab.h>
  41. #include <linux/ratelimit.h>
  42. #include <asm/io.h>
  43. #include <linux/uaccess.h>
  44. #define MOXA 0x400
  45. #define MOXA_GET_IQUEUE (MOXA + 1) /* get input buffered count */
  46. #define MOXA_GET_OQUEUE (MOXA + 2) /* get output buffered count */
  47. #define MOXA_GETDATACOUNT (MOXA + 23)
  48. #define MOXA_GET_IOQUEUE (MOXA + 27)
  49. #define MOXA_FLUSH_QUEUE (MOXA + 28)
  50. #define MOXA_GETMSTATUS (MOXA + 65)
  51. /*
  52. * System Configuration
  53. */
  54. #define Magic_code 0x404
  55. /*
  56. * for C218 BIOS initialization
  57. */
  58. #define C218_ConfBase 0x800
  59. #define C218_status (C218_ConfBase + 0) /* BIOS running status */
  60. #define C218_diag (C218_ConfBase + 2) /* diagnostic status */
  61. #define C218_key (C218_ConfBase + 4) /* WORD (0x218 for C218) */
  62. #define C218DLoad_len (C218_ConfBase + 6) /* WORD */
  63. #define C218check_sum (C218_ConfBase + 8) /* BYTE */
  64. #define C218chksum_ok (C218_ConfBase + 0x0a) /* BYTE (1:ok) */
  65. #define C218_TestRx (C218_ConfBase + 0x10) /* 8 bytes for 8 ports */
  66. #define C218_TestTx (C218_ConfBase + 0x18) /* 8 bytes for 8 ports */
  67. #define C218_RXerr (C218_ConfBase + 0x20) /* 8 bytes for 8 ports */
  68. #define C218_ErrFlag (C218_ConfBase + 0x28) /* 8 bytes for 8 ports */
  69. #define C218_LoadBuf 0x0F00
  70. #define C218_KeyCode 0x218
  71. #define CP204J_KeyCode 0x204
  72. /*
  73. * for C320 BIOS initialization
  74. */
  75. #define C320_ConfBase 0x800
  76. #define C320_LoadBuf 0x0f00
  77. #define STS_init 0x05 /* for C320_status */
  78. #define C320_status C320_ConfBase + 0 /* BIOS running status */
  79. #define C320_diag C320_ConfBase + 2 /* diagnostic status */
  80. #define C320_key C320_ConfBase + 4 /* WORD (0320H for C320) */
  81. #define C320DLoad_len C320_ConfBase + 6 /* WORD */
  82. #define C320check_sum C320_ConfBase + 8 /* WORD */
  83. #define C320chksum_ok C320_ConfBase + 0x0a /* WORD (1:ok) */
  84. #define C320bapi_len C320_ConfBase + 0x0c /* WORD */
  85. #define C320UART_no C320_ConfBase + 0x0e /* WORD */
  86. #define C320_KeyCode 0x320
  87. #define FixPage_addr 0x0000 /* starting addr of static page */
  88. #define DynPage_addr 0x2000 /* starting addr of dynamic page */
  89. #define C218_start 0x3000 /* starting addr of C218 BIOS prg */
  90. #define Control_reg 0x1ff0 /* select page and reset control */
  91. #define HW_reset 0x80
  92. /*
  93. * Function Codes
  94. */
  95. #define FC_CardReset 0x80
  96. #define FC_ChannelReset 1 /* C320 firmware not supported */
  97. #define FC_EnableCH 2
  98. #define FC_DisableCH 3
  99. #define FC_SetParam 4
  100. #define FC_SetMode 5
  101. #define FC_SetRate 6
  102. #define FC_LineControl 7
  103. #define FC_LineStatus 8
  104. #define FC_XmitControl 9
  105. #define FC_FlushQueue 10
  106. #define FC_SendBreak 11
  107. #define FC_StopBreak 12
  108. #define FC_LoopbackON 13
  109. #define FC_LoopbackOFF 14
  110. #define FC_ClrIrqTable 15
  111. #define FC_SendXon 16
  112. #define FC_SetTermIrq 17 /* C320 firmware not supported */
  113. #define FC_SetCntIrq 18 /* C320 firmware not supported */
  114. #define FC_SetBreakIrq 19
  115. #define FC_SetLineIrq 20
  116. #define FC_SetFlowCtl 21
  117. #define FC_GenIrq 22
  118. #define FC_InCD180 23
  119. #define FC_OutCD180 24
  120. #define FC_InUARTreg 23
  121. #define FC_OutUARTreg 24
  122. #define FC_SetXonXoff 25
  123. #define FC_OutCD180CCR 26
  124. #define FC_ExtIQueue 27
  125. #define FC_ExtOQueue 28
  126. #define FC_ClrLineIrq 29
  127. #define FC_HWFlowCtl 30
  128. #define FC_GetClockRate 35
  129. #define FC_SetBaud 36
  130. #define FC_SetDataMode 41
  131. #define FC_GetCCSR 43
  132. #define FC_GetDataError 45
  133. #define FC_RxControl 50
  134. #define FC_ImmSend 51
  135. #define FC_SetXonState 52
  136. #define FC_SetXoffState 53
  137. #define FC_SetRxFIFOTrig 54
  138. #define FC_SetTxFIFOCnt 55
  139. #define FC_UnixRate 56
  140. #define FC_UnixResetTimer 57
  141. #define RxFIFOTrig1 0
  142. #define RxFIFOTrig4 1
  143. #define RxFIFOTrig8 2
  144. #define RxFIFOTrig14 3
  145. /*
  146. * Dual-Ported RAM
  147. */
  148. #define DRAM_global 0
  149. #define INT_data (DRAM_global + 0)
  150. #define Config_base (DRAM_global + 0x108)
  151. #define IRQindex (INT_data + 0)
  152. #define IRQpending (INT_data + 4)
  153. #define IRQtable (INT_data + 8)
  154. /*
  155. * Interrupt Status
  156. */
  157. #define IntrRx 0x01 /* receiver data O.K. */
  158. #define IntrTx 0x02 /* transmit buffer empty */
  159. #define IntrFunc 0x04 /* function complete */
  160. #define IntrBreak 0x08 /* received break */
  161. #define IntrLine 0x10 /* line status change
  162. for transmitter */
  163. #define IntrIntr 0x20 /* received INTR code */
  164. #define IntrQuit 0x40 /* received QUIT code */
  165. #define IntrEOF 0x80 /* received EOF code */
  166. #define IntrRxTrigger 0x100 /* rx data count reach trigger value */
  167. #define IntrTxTrigger 0x200 /* tx data count below trigger value */
  168. #define Magic_no (Config_base + 0)
  169. #define Card_model_no (Config_base + 2)
  170. #define Total_ports (Config_base + 4)
  171. #define Module_cnt (Config_base + 8)
  172. #define Module_no (Config_base + 10)
  173. #define Timer_10ms (Config_base + 14)
  174. #define Disable_IRQ (Config_base + 20)
  175. #define TMS320_PORT1 (Config_base + 22)
  176. #define TMS320_PORT2 (Config_base + 24)
  177. #define TMS320_CLOCK (Config_base + 26)
  178. /*
  179. * DATA BUFFER in DRAM
  180. */
  181. #define Extern_table 0x400 /* Base address of the external table
  182. (24 words * 64) total 3K bytes
  183. (24 words * 128) total 6K bytes */
  184. #define Extern_size 0x60 /* 96 bytes */
  185. #define RXrptr 0x00 /* read pointer for RX buffer */
  186. #define RXwptr 0x02 /* write pointer for RX buffer */
  187. #define TXrptr 0x04 /* read pointer for TX buffer */
  188. #define TXwptr 0x06 /* write pointer for TX buffer */
  189. #define HostStat 0x08 /* IRQ flag and general flag */
  190. #define FlagStat 0x0A
  191. #define FlowControl 0x0C /* B7 B6 B5 B4 B3 B2 B1 B0 */
  192. /* x x x x | | | | */
  193. /* | | | + CTS flow */
  194. /* | | +--- RTS flow */
  195. /* | +------ TX Xon/Xoff */
  196. /* +--------- RX Xon/Xoff */
  197. #define Break_cnt 0x0E /* received break count */
  198. #define CD180TXirq 0x10 /* if non-0: enable TX irq */
  199. #define RX_mask 0x12
  200. #define TX_mask 0x14
  201. #define Ofs_rxb 0x16
  202. #define Ofs_txb 0x18
  203. #define Page_rxb 0x1A
  204. #define Page_txb 0x1C
  205. #define EndPage_rxb 0x1E
  206. #define EndPage_txb 0x20
  207. #define Data_error 0x22
  208. #define RxTrigger 0x28
  209. #define TxTrigger 0x2a
  210. #define rRXwptr 0x34
  211. #define Low_water 0x36
  212. #define FuncCode 0x40
  213. #define FuncArg 0x42
  214. #define FuncArg1 0x44
  215. #define C218rx_size 0x2000 /* 8K bytes */
  216. #define C218tx_size 0x8000 /* 32K bytes */
  217. #define C218rx_mask (C218rx_size - 1)
  218. #define C218tx_mask (C218tx_size - 1)
  219. #define C320p8rx_size 0x2000
  220. #define C320p8tx_size 0x8000
  221. #define C320p8rx_mask (C320p8rx_size - 1)
  222. #define C320p8tx_mask (C320p8tx_size - 1)
  223. #define C320p16rx_size 0x2000
  224. #define C320p16tx_size 0x4000
  225. #define C320p16rx_mask (C320p16rx_size - 1)
  226. #define C320p16tx_mask (C320p16tx_size - 1)
  227. #define C320p24rx_size 0x2000
  228. #define C320p24tx_size 0x2000
  229. #define C320p24rx_mask (C320p24rx_size - 1)
  230. #define C320p24tx_mask (C320p24tx_size - 1)
  231. #define C320p32rx_size 0x1000
  232. #define C320p32tx_size 0x1000
  233. #define C320p32rx_mask (C320p32rx_size - 1)
  234. #define C320p32tx_mask (C320p32tx_size - 1)
  235. #define Page_size 0x2000U
  236. #define Page_mask (Page_size - 1)
  237. #define C218rx_spage 3
  238. #define C218tx_spage 4
  239. #define C218rx_pageno 1
  240. #define C218tx_pageno 4
  241. #define C218buf_pageno 5
  242. #define C320p8rx_spage 3
  243. #define C320p8tx_spage 4
  244. #define C320p8rx_pgno 1
  245. #define C320p8tx_pgno 4
  246. #define C320p8buf_pgno 5
  247. #define C320p16rx_spage 3
  248. #define C320p16tx_spage 4
  249. #define C320p16rx_pgno 1
  250. #define C320p16tx_pgno 2
  251. #define C320p16buf_pgno 3
  252. #define C320p24rx_spage 3
  253. #define C320p24tx_spage 4
  254. #define C320p24rx_pgno 1
  255. #define C320p24tx_pgno 1
  256. #define C320p24buf_pgno 2
  257. #define C320p32rx_spage 3
  258. #define C320p32tx_ofs C320p32rx_size
  259. #define C320p32tx_spage 3
  260. #define C320p32buf_pgno 1
  261. /*
  262. * Host Status
  263. */
  264. #define WakeupRx 0x01
  265. #define WakeupTx 0x02
  266. #define WakeupBreak 0x08
  267. #define WakeupLine 0x10
  268. #define WakeupIntr 0x20
  269. #define WakeupQuit 0x40
  270. #define WakeupEOF 0x80 /* used in VTIME control */
  271. #define WakeupRxTrigger 0x100
  272. #define WakeupTxTrigger 0x200
  273. /*
  274. * Flag status
  275. */
  276. #define Rx_over 0x01
  277. #define Xoff_state 0x02
  278. #define Tx_flowOff 0x04
  279. #define Tx_enable 0x08
  280. #define CTS_state 0x10
  281. #define DSR_state 0x20
  282. #define DCD_state 0x80
  283. /*
  284. * FlowControl
  285. */
  286. #define CTS_FlowCtl 1
  287. #define RTS_FlowCtl 2
  288. #define Tx_FlowCtl 4
  289. #define Rx_FlowCtl 8
  290. #define IXM_IXANY 0x10
  291. #define LowWater 128
  292. #define DTR_ON 1
  293. #define RTS_ON 2
  294. #define CTS_ON 1
  295. #define DSR_ON 2
  296. #define DCD_ON 8
  297. /* mode definition */
  298. #define MX_CS8 0x03
  299. #define MX_CS7 0x02
  300. #define MX_CS6 0x01
  301. #define MX_CS5 0x00
  302. #define MX_STOP1 0x00
  303. #define MX_STOP15 0x04
  304. #define MX_STOP2 0x08
  305. #define MX_PARNONE 0x00
  306. #define MX_PAREVEN 0x40
  307. #define MX_PARODD 0xC0
  308. #define MX_PARMARK 0xA0
  309. #define MX_PARSPACE 0x20
  310. #define MOXA_VERSION "6.0k"
  311. #define MOXA_FW_HDRLEN 32
  312. #define MOXAMAJOR 172
  313. #define MAX_BOARDS 4 /* Don't change this value */
  314. #define MAX_PORTS_PER_BOARD 32 /* Don't change this value */
  315. #define MAX_PORTS (MAX_BOARDS * MAX_PORTS_PER_BOARD)
  316. #define MOXA_IS_320(brd) ((brd)->boardType == MOXA_BOARD_C320_ISA || \
  317. (brd)->boardType == MOXA_BOARD_C320_PCI)
  318. /*
  319. * Define the Moxa PCI vendor and device IDs.
  320. */
  321. #define MOXA_BUS_TYPE_ISA 0
  322. #define MOXA_BUS_TYPE_PCI 1
  323. enum {
  324. MOXA_BOARD_C218_PCI = 1,
  325. MOXA_BOARD_C218_ISA,
  326. MOXA_BOARD_C320_PCI,
  327. MOXA_BOARD_C320_ISA,
  328. MOXA_BOARD_CP204J,
  329. };
  330. static char *moxa_brdname[] =
  331. {
  332. "C218 Turbo PCI series",
  333. "C218 Turbo ISA series",
  334. "C320 Turbo PCI series",
  335. "C320 Turbo ISA series",
  336. "CP-204J series",
  337. };
  338. #ifdef CONFIG_PCI
  339. static const struct pci_device_id moxa_pcibrds[] = {
  340. { PCI_DEVICE(PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_C218),
  341. .driver_data = MOXA_BOARD_C218_PCI },
  342. { PCI_DEVICE(PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_C320),
  343. .driver_data = MOXA_BOARD_C320_PCI },
  344. { PCI_DEVICE(PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP204J),
  345. .driver_data = MOXA_BOARD_CP204J },
  346. { 0 }
  347. };
  348. MODULE_DEVICE_TABLE(pci, moxa_pcibrds);
  349. #endif /* CONFIG_PCI */
  350. struct moxa_port;
  351. static struct moxa_board_conf {
  352. int boardType;
  353. int numPorts;
  354. int busType;
  355. unsigned int ready;
  356. struct moxa_port *ports;
  357. void __iomem *basemem;
  358. void __iomem *intNdx;
  359. void __iomem *intPend;
  360. void __iomem *intTable;
  361. } moxa_boards[MAX_BOARDS];
  362. struct mxser_mstatus {
  363. tcflag_t cflag;
  364. int cts;
  365. int dsr;
  366. int ri;
  367. int dcd;
  368. };
  369. struct moxaq_str {
  370. int inq;
  371. int outq;
  372. };
  373. struct moxa_port {
  374. struct tty_port port;
  375. struct moxa_board_conf *board;
  376. void __iomem *tableAddr;
  377. int type;
  378. int cflag;
  379. unsigned long statusflags;
  380. u8 DCDState; /* Protected by the port lock */
  381. u8 lineCtrl;
  382. u8 lowChkFlag;
  383. };
  384. struct mon_str {
  385. int tick;
  386. int rxcnt[MAX_PORTS];
  387. int txcnt[MAX_PORTS];
  388. };
  389. /* statusflags */
  390. #define TXSTOPPED 1
  391. #define LOWWAIT 2
  392. #define EMPTYWAIT 3
  393. #define WAKEUP_CHARS 256
  394. static int ttymajor = MOXAMAJOR;
  395. static struct mon_str moxaLog;
  396. static unsigned int moxaFuncTout = HZ / 2;
  397. static unsigned int moxaLowWaterChk;
  398. static DEFINE_MUTEX(moxa_openlock);
  399. static DEFINE_SPINLOCK(moxa_lock);
  400. static unsigned long baseaddr[MAX_BOARDS];
  401. static unsigned int type[MAX_BOARDS];
  402. static unsigned int numports[MAX_BOARDS];
  403. static struct tty_port moxa_service_port;
  404. MODULE_AUTHOR("William Chen");
  405. MODULE_DESCRIPTION("MOXA Intellio Family Multiport Board Device Driver");
  406. MODULE_LICENSE("GPL");
  407. MODULE_FIRMWARE("c218tunx.cod");
  408. MODULE_FIRMWARE("cp204unx.cod");
  409. MODULE_FIRMWARE("c320tunx.cod");
  410. module_param_array(type, uint, NULL, 0);
  411. MODULE_PARM_DESC(type, "card type: C218=2, C320=4");
  412. module_param_hw_array(baseaddr, ulong, ioport, NULL, 0);
  413. MODULE_PARM_DESC(baseaddr, "base address");
  414. module_param_array(numports, uint, NULL, 0);
  415. MODULE_PARM_DESC(numports, "numports (ignored for C218)");
  416. module_param(ttymajor, int, 0);
  417. /*
  418. * static functions:
  419. */
  420. static int moxa_open(struct tty_struct *, struct file *);
  421. static void moxa_close(struct tty_struct *, struct file *);
  422. static int moxa_write(struct tty_struct *, const unsigned char *, int);
  423. static unsigned int moxa_write_room(struct tty_struct *);
  424. static void moxa_flush_buffer(struct tty_struct *);
  425. static unsigned int moxa_chars_in_buffer(struct tty_struct *);
  426. static void moxa_set_termios(struct tty_struct *, const struct ktermios *);
  427. static void moxa_stop(struct tty_struct *);
  428. static void moxa_start(struct tty_struct *);
  429. static void moxa_hangup(struct tty_struct *);
  430. static int moxa_tiocmget(struct tty_struct *tty);
  431. static int moxa_tiocmset(struct tty_struct *tty,
  432. unsigned int set, unsigned int clear);
  433. static void moxa_poll(struct timer_list *);
  434. static void moxa_set_tty_param(struct tty_struct *, const struct ktermios *);
  435. static void moxa_shutdown(struct tty_port *);
  436. static int moxa_carrier_raised(struct tty_port *);
  437. static void moxa_dtr_rts(struct tty_port *, int);
  438. /*
  439. * moxa board interface functions:
  440. */
  441. static void MoxaPortEnable(struct moxa_port *);
  442. static void MoxaPortDisable(struct moxa_port *);
  443. static int MoxaPortSetTermio(struct moxa_port *, struct ktermios *, speed_t);
  444. static int MoxaPortGetLineOut(struct moxa_port *, int *, int *);
  445. static void MoxaPortLineCtrl(struct moxa_port *, int, int);
  446. static void MoxaPortFlowCtrl(struct moxa_port *, int, int, int, int, int);
  447. static int MoxaPortLineStatus(struct moxa_port *);
  448. static void MoxaPortFlushData(struct moxa_port *, int);
  449. static int MoxaPortWriteData(struct tty_struct *, const unsigned char *, int);
  450. static int MoxaPortReadData(struct moxa_port *);
  451. static unsigned int MoxaPortTxQueue(struct moxa_port *);
  452. static int MoxaPortRxQueue(struct moxa_port *);
  453. static unsigned int MoxaPortTxFree(struct moxa_port *);
  454. static void MoxaPortTxDisable(struct moxa_port *);
  455. static void MoxaPortTxEnable(struct moxa_port *);
  456. static int moxa_get_serial_info(struct tty_struct *, struct serial_struct *);
  457. static int moxa_set_serial_info(struct tty_struct *, struct serial_struct *);
  458. static void MoxaSetFifo(struct moxa_port *port, int enable);
  459. /*
  460. * I/O functions
  461. */
  462. static DEFINE_SPINLOCK(moxafunc_lock);
  463. static void moxa_wait_finish(void __iomem *ofsAddr)
  464. {
  465. unsigned long end = jiffies + moxaFuncTout;
  466. while (readw(ofsAddr + FuncCode) != 0)
  467. if (time_after(jiffies, end))
  468. return;
  469. if (readw(ofsAddr + FuncCode) != 0)
  470. printk_ratelimited(KERN_WARNING "moxa function expired\n");
  471. }
  472. static void moxafunc(void __iomem *ofsAddr, u16 cmd, u16 arg)
  473. {
  474. unsigned long flags;
  475. spin_lock_irqsave(&moxafunc_lock, flags);
  476. writew(arg, ofsAddr + FuncArg);
  477. writew(cmd, ofsAddr + FuncCode);
  478. moxa_wait_finish(ofsAddr);
  479. spin_unlock_irqrestore(&moxafunc_lock, flags);
  480. }
  481. static int moxafuncret(void __iomem *ofsAddr, u16 cmd, u16 arg)
  482. {
  483. unsigned long flags;
  484. u16 ret;
  485. spin_lock_irqsave(&moxafunc_lock, flags);
  486. writew(arg, ofsAddr + FuncArg);
  487. writew(cmd, ofsAddr + FuncCode);
  488. moxa_wait_finish(ofsAddr);
  489. ret = readw(ofsAddr + FuncArg);
  490. spin_unlock_irqrestore(&moxafunc_lock, flags);
  491. return ret;
  492. }
  493. static void moxa_low_water_check(void __iomem *ofsAddr)
  494. {
  495. u16 rptr, wptr, mask, len;
  496. if (readb(ofsAddr + FlagStat) & Xoff_state) {
  497. rptr = readw(ofsAddr + RXrptr);
  498. wptr = readw(ofsAddr + RXwptr);
  499. mask = readw(ofsAddr + RX_mask);
  500. len = (wptr - rptr) & mask;
  501. if (len <= Low_water)
  502. moxafunc(ofsAddr, FC_SendXon, 0);
  503. }
  504. }
  505. /*
  506. * TTY operations
  507. */
  508. static int moxa_ioctl(struct tty_struct *tty,
  509. unsigned int cmd, unsigned long arg)
  510. {
  511. struct moxa_port *ch = tty->driver_data;
  512. void __user *argp = (void __user *)arg;
  513. int status, ret = 0;
  514. if (tty->index == MAX_PORTS) {
  515. if (cmd != MOXA_GETDATACOUNT && cmd != MOXA_GET_IOQUEUE &&
  516. cmd != MOXA_GETMSTATUS)
  517. return -EINVAL;
  518. } else if (!ch)
  519. return -ENODEV;
  520. switch (cmd) {
  521. case MOXA_GETDATACOUNT:
  522. moxaLog.tick = jiffies;
  523. if (copy_to_user(argp, &moxaLog, sizeof(moxaLog)))
  524. ret = -EFAULT;
  525. break;
  526. case MOXA_FLUSH_QUEUE:
  527. MoxaPortFlushData(ch, arg);
  528. break;
  529. case MOXA_GET_IOQUEUE: {
  530. struct moxaq_str __user *argm = argp;
  531. struct moxaq_str tmp;
  532. struct moxa_port *p;
  533. unsigned int i, j;
  534. for (i = 0; i < MAX_BOARDS; i++) {
  535. p = moxa_boards[i].ports;
  536. for (j = 0; j < MAX_PORTS_PER_BOARD; j++, p++, argm++) {
  537. memset(&tmp, 0, sizeof(tmp));
  538. spin_lock_bh(&moxa_lock);
  539. if (moxa_boards[i].ready) {
  540. tmp.inq = MoxaPortRxQueue(p);
  541. tmp.outq = MoxaPortTxQueue(p);
  542. }
  543. spin_unlock_bh(&moxa_lock);
  544. if (copy_to_user(argm, &tmp, sizeof(tmp)))
  545. return -EFAULT;
  546. }
  547. }
  548. break;
  549. } case MOXA_GET_OQUEUE:
  550. status = MoxaPortTxQueue(ch);
  551. ret = put_user(status, (unsigned long __user *)argp);
  552. break;
  553. case MOXA_GET_IQUEUE:
  554. status = MoxaPortRxQueue(ch);
  555. ret = put_user(status, (unsigned long __user *)argp);
  556. break;
  557. case MOXA_GETMSTATUS: {
  558. struct mxser_mstatus __user *argm = argp;
  559. struct mxser_mstatus tmp;
  560. struct moxa_port *p;
  561. unsigned int i, j;
  562. for (i = 0; i < MAX_BOARDS; i++) {
  563. p = moxa_boards[i].ports;
  564. for (j = 0; j < MAX_PORTS_PER_BOARD; j++, p++, argm++) {
  565. struct tty_struct *ttyp;
  566. memset(&tmp, 0, sizeof(tmp));
  567. spin_lock_bh(&moxa_lock);
  568. if (!moxa_boards[i].ready) {
  569. spin_unlock_bh(&moxa_lock);
  570. goto copy;
  571. }
  572. status = MoxaPortLineStatus(p);
  573. spin_unlock_bh(&moxa_lock);
  574. if (status & 1)
  575. tmp.cts = 1;
  576. if (status & 2)
  577. tmp.dsr = 1;
  578. if (status & 4)
  579. tmp.dcd = 1;
  580. ttyp = tty_port_tty_get(&p->port);
  581. if (!ttyp)
  582. tmp.cflag = p->cflag;
  583. else
  584. tmp.cflag = ttyp->termios.c_cflag;
  585. tty_kref_put(ttyp);
  586. copy:
  587. if (copy_to_user(argm, &tmp, sizeof(tmp)))
  588. return -EFAULT;
  589. }
  590. }
  591. break;
  592. }
  593. default:
  594. ret = -ENOIOCTLCMD;
  595. }
  596. return ret;
  597. }
  598. static int moxa_break_ctl(struct tty_struct *tty, int state)
  599. {
  600. struct moxa_port *port = tty->driver_data;
  601. moxafunc(port->tableAddr, state ? FC_SendBreak : FC_StopBreak,
  602. Magic_code);
  603. return 0;
  604. }
  605. static const struct tty_operations moxa_ops = {
  606. .open = moxa_open,
  607. .close = moxa_close,
  608. .write = moxa_write,
  609. .write_room = moxa_write_room,
  610. .flush_buffer = moxa_flush_buffer,
  611. .chars_in_buffer = moxa_chars_in_buffer,
  612. .ioctl = moxa_ioctl,
  613. .set_termios = moxa_set_termios,
  614. .stop = moxa_stop,
  615. .start = moxa_start,
  616. .hangup = moxa_hangup,
  617. .break_ctl = moxa_break_ctl,
  618. .tiocmget = moxa_tiocmget,
  619. .tiocmset = moxa_tiocmset,
  620. .set_serial = moxa_set_serial_info,
  621. .get_serial = moxa_get_serial_info,
  622. };
  623. static const struct tty_port_operations moxa_port_ops = {
  624. .carrier_raised = moxa_carrier_raised,
  625. .dtr_rts = moxa_dtr_rts,
  626. .shutdown = moxa_shutdown,
  627. };
  628. static struct tty_driver *moxaDriver;
  629. static DEFINE_TIMER(moxaTimer, moxa_poll);
  630. /*
  631. * HW init
  632. */
  633. static int moxa_check_fw_model(struct moxa_board_conf *brd, u8 model)
  634. {
  635. switch (brd->boardType) {
  636. case MOXA_BOARD_C218_ISA:
  637. case MOXA_BOARD_C218_PCI:
  638. if (model != 1)
  639. goto err;
  640. break;
  641. case MOXA_BOARD_CP204J:
  642. if (model != 3)
  643. goto err;
  644. break;
  645. default:
  646. if (model != 2)
  647. goto err;
  648. break;
  649. }
  650. return 0;
  651. err:
  652. return -EINVAL;
  653. }
  654. static int moxa_check_fw(const void *ptr)
  655. {
  656. const __le16 *lptr = ptr;
  657. if (*lptr != cpu_to_le16(0x7980))
  658. return -EINVAL;
  659. return 0;
  660. }
  661. static int moxa_load_bios(struct moxa_board_conf *brd, const u8 *buf,
  662. size_t len)
  663. {
  664. void __iomem *baseAddr = brd->basemem;
  665. u16 tmp;
  666. writeb(HW_reset, baseAddr + Control_reg); /* reset */
  667. msleep(10);
  668. memset_io(baseAddr, 0, 4096);
  669. memcpy_toio(baseAddr, buf, len); /* download BIOS */
  670. writeb(0, baseAddr + Control_reg); /* restart */
  671. msleep(2000);
  672. switch (brd->boardType) {
  673. case MOXA_BOARD_C218_ISA:
  674. case MOXA_BOARD_C218_PCI:
  675. tmp = readw(baseAddr + C218_key);
  676. if (tmp != C218_KeyCode)
  677. goto err;
  678. break;
  679. case MOXA_BOARD_CP204J:
  680. tmp = readw(baseAddr + C218_key);
  681. if (tmp != CP204J_KeyCode)
  682. goto err;
  683. break;
  684. default:
  685. tmp = readw(baseAddr + C320_key);
  686. if (tmp != C320_KeyCode)
  687. goto err;
  688. tmp = readw(baseAddr + C320_status);
  689. if (tmp != STS_init) {
  690. printk(KERN_ERR "MOXA: bios upload failed -- CPU/Basic "
  691. "module not found\n");
  692. return -EIO;
  693. }
  694. break;
  695. }
  696. return 0;
  697. err:
  698. printk(KERN_ERR "MOXA: bios upload failed -- board not found\n");
  699. return -EIO;
  700. }
  701. static int moxa_load_320b(struct moxa_board_conf *brd, const u8 *ptr,
  702. size_t len)
  703. {
  704. void __iomem *baseAddr = brd->basemem;
  705. if (len < 7168) {
  706. printk(KERN_ERR "MOXA: invalid 320 bios -- too short\n");
  707. return -EINVAL;
  708. }
  709. writew(len - 7168 - 2, baseAddr + C320bapi_len);
  710. writeb(1, baseAddr + Control_reg); /* Select Page 1 */
  711. memcpy_toio(baseAddr + DynPage_addr, ptr, 7168);
  712. writeb(2, baseAddr + Control_reg); /* Select Page 2 */
  713. memcpy_toio(baseAddr + DynPage_addr, ptr + 7168, len - 7168);
  714. return 0;
  715. }
  716. static int moxa_real_load_code(struct moxa_board_conf *brd, const void *ptr,
  717. size_t len)
  718. {
  719. void __iomem *baseAddr = brd->basemem;
  720. const __le16 *uptr = ptr;
  721. size_t wlen, len2, j;
  722. unsigned long key, loadbuf, loadlen, checksum, checksum_ok;
  723. unsigned int i, retry;
  724. u16 usum, keycode;
  725. keycode = (brd->boardType == MOXA_BOARD_CP204J) ? CP204J_KeyCode :
  726. C218_KeyCode;
  727. switch (brd->boardType) {
  728. case MOXA_BOARD_CP204J:
  729. case MOXA_BOARD_C218_ISA:
  730. case MOXA_BOARD_C218_PCI:
  731. key = C218_key;
  732. loadbuf = C218_LoadBuf;
  733. loadlen = C218DLoad_len;
  734. checksum = C218check_sum;
  735. checksum_ok = C218chksum_ok;
  736. break;
  737. default:
  738. key = C320_key;
  739. keycode = C320_KeyCode;
  740. loadbuf = C320_LoadBuf;
  741. loadlen = C320DLoad_len;
  742. checksum = C320check_sum;
  743. checksum_ok = C320chksum_ok;
  744. break;
  745. }
  746. usum = 0;
  747. wlen = len >> 1;
  748. for (i = 0; i < wlen; i++)
  749. usum += le16_to_cpu(uptr[i]);
  750. retry = 0;
  751. do {
  752. wlen = len >> 1;
  753. j = 0;
  754. while (wlen) {
  755. len2 = (wlen > 2048) ? 2048 : wlen;
  756. wlen -= len2;
  757. memcpy_toio(baseAddr + loadbuf, ptr + j, len2 << 1);
  758. j += len2 << 1;
  759. writew(len2, baseAddr + loadlen);
  760. writew(0, baseAddr + key);
  761. for (i = 0; i < 100; i++) {
  762. if (readw(baseAddr + key) == keycode)
  763. break;
  764. msleep(10);
  765. }
  766. if (readw(baseAddr + key) != keycode)
  767. return -EIO;
  768. }
  769. writew(0, baseAddr + loadlen);
  770. writew(usum, baseAddr + checksum);
  771. writew(0, baseAddr + key);
  772. for (i = 0; i < 100; i++) {
  773. if (readw(baseAddr + key) == keycode)
  774. break;
  775. msleep(10);
  776. }
  777. retry++;
  778. } while ((readb(baseAddr + checksum_ok) != 1) && (retry < 3));
  779. if (readb(baseAddr + checksum_ok) != 1)
  780. return -EIO;
  781. writew(0, baseAddr + key);
  782. for (i = 0; i < 600; i++) {
  783. if (readw(baseAddr + Magic_no) == Magic_code)
  784. break;
  785. msleep(10);
  786. }
  787. if (readw(baseAddr + Magic_no) != Magic_code)
  788. return -EIO;
  789. if (MOXA_IS_320(brd)) {
  790. if (brd->busType == MOXA_BUS_TYPE_PCI) { /* ASIC board */
  791. writew(0x3800, baseAddr + TMS320_PORT1);
  792. writew(0x3900, baseAddr + TMS320_PORT2);
  793. writew(28499, baseAddr + TMS320_CLOCK);
  794. } else {
  795. writew(0x3200, baseAddr + TMS320_PORT1);
  796. writew(0x3400, baseAddr + TMS320_PORT2);
  797. writew(19999, baseAddr + TMS320_CLOCK);
  798. }
  799. }
  800. writew(1, baseAddr + Disable_IRQ);
  801. writew(0, baseAddr + Magic_no);
  802. for (i = 0; i < 500; i++) {
  803. if (readw(baseAddr + Magic_no) == Magic_code)
  804. break;
  805. msleep(10);
  806. }
  807. if (readw(baseAddr + Magic_no) != Magic_code)
  808. return -EIO;
  809. if (MOXA_IS_320(brd)) {
  810. j = readw(baseAddr + Module_cnt);
  811. if (j <= 0)
  812. return -EIO;
  813. brd->numPorts = j * 8;
  814. writew(j, baseAddr + Module_no);
  815. writew(0, baseAddr + Magic_no);
  816. for (i = 0; i < 600; i++) {
  817. if (readw(baseAddr + Magic_no) == Magic_code)
  818. break;
  819. msleep(10);
  820. }
  821. if (readw(baseAddr + Magic_no) != Magic_code)
  822. return -EIO;
  823. }
  824. brd->intNdx = baseAddr + IRQindex;
  825. brd->intPend = baseAddr + IRQpending;
  826. brd->intTable = baseAddr + IRQtable;
  827. return 0;
  828. }
  829. static int moxa_load_code(struct moxa_board_conf *brd, const void *ptr,
  830. size_t len)
  831. {
  832. void __iomem *ofsAddr, *baseAddr = brd->basemem;
  833. struct moxa_port *port;
  834. int retval, i;
  835. if (len % 2) {
  836. printk(KERN_ERR "MOXA: bios length is not even\n");
  837. return -EINVAL;
  838. }
  839. retval = moxa_real_load_code(brd, ptr, len); /* may change numPorts */
  840. if (retval)
  841. return retval;
  842. switch (brd->boardType) {
  843. case MOXA_BOARD_C218_ISA:
  844. case MOXA_BOARD_C218_PCI:
  845. case MOXA_BOARD_CP204J:
  846. port = brd->ports;
  847. for (i = 0; i < brd->numPorts; i++, port++) {
  848. port->board = brd;
  849. port->DCDState = 0;
  850. port->tableAddr = baseAddr + Extern_table +
  851. Extern_size * i;
  852. ofsAddr = port->tableAddr;
  853. writew(C218rx_mask, ofsAddr + RX_mask);
  854. writew(C218tx_mask, ofsAddr + TX_mask);
  855. writew(C218rx_spage + i * C218buf_pageno, ofsAddr + Page_rxb);
  856. writew(readw(ofsAddr + Page_rxb) + C218rx_pageno, ofsAddr + EndPage_rxb);
  857. writew(C218tx_spage + i * C218buf_pageno, ofsAddr + Page_txb);
  858. writew(readw(ofsAddr + Page_txb) + C218tx_pageno, ofsAddr + EndPage_txb);
  859. }
  860. break;
  861. default:
  862. port = brd->ports;
  863. for (i = 0; i < brd->numPorts; i++, port++) {
  864. port->board = brd;
  865. port->DCDState = 0;
  866. port->tableAddr = baseAddr + Extern_table +
  867. Extern_size * i;
  868. ofsAddr = port->tableAddr;
  869. switch (brd->numPorts) {
  870. case 8:
  871. writew(C320p8rx_mask, ofsAddr + RX_mask);
  872. writew(C320p8tx_mask, ofsAddr + TX_mask);
  873. writew(C320p8rx_spage + i * C320p8buf_pgno, ofsAddr + Page_rxb);
  874. writew(readw(ofsAddr + Page_rxb) + C320p8rx_pgno, ofsAddr + EndPage_rxb);
  875. writew(C320p8tx_spage + i * C320p8buf_pgno, ofsAddr + Page_txb);
  876. writew(readw(ofsAddr + Page_txb) + C320p8tx_pgno, ofsAddr + EndPage_txb);
  877. break;
  878. case 16:
  879. writew(C320p16rx_mask, ofsAddr + RX_mask);
  880. writew(C320p16tx_mask, ofsAddr + TX_mask);
  881. writew(C320p16rx_spage + i * C320p16buf_pgno, ofsAddr + Page_rxb);
  882. writew(readw(ofsAddr + Page_rxb) + C320p16rx_pgno, ofsAddr + EndPage_rxb);
  883. writew(C320p16tx_spage + i * C320p16buf_pgno, ofsAddr + Page_txb);
  884. writew(readw(ofsAddr + Page_txb) + C320p16tx_pgno, ofsAddr + EndPage_txb);
  885. break;
  886. case 24:
  887. writew(C320p24rx_mask, ofsAddr + RX_mask);
  888. writew(C320p24tx_mask, ofsAddr + TX_mask);
  889. writew(C320p24rx_spage + i * C320p24buf_pgno, ofsAddr + Page_rxb);
  890. writew(readw(ofsAddr + Page_rxb) + C320p24rx_pgno, ofsAddr + EndPage_rxb);
  891. writew(C320p24tx_spage + i * C320p24buf_pgno, ofsAddr + Page_txb);
  892. writew(readw(ofsAddr + Page_txb), ofsAddr + EndPage_txb);
  893. break;
  894. case 32:
  895. writew(C320p32rx_mask, ofsAddr + RX_mask);
  896. writew(C320p32tx_mask, ofsAddr + TX_mask);
  897. writew(C320p32tx_ofs, ofsAddr + Ofs_txb);
  898. writew(C320p32rx_spage + i * C320p32buf_pgno, ofsAddr + Page_rxb);
  899. writew(readb(ofsAddr + Page_rxb), ofsAddr + EndPage_rxb);
  900. writew(C320p32tx_spage + i * C320p32buf_pgno, ofsAddr + Page_txb);
  901. writew(readw(ofsAddr + Page_txb), ofsAddr + EndPage_txb);
  902. break;
  903. }
  904. }
  905. break;
  906. }
  907. return 0;
  908. }
  909. static int moxa_load_fw(struct moxa_board_conf *brd, const struct firmware *fw)
  910. {
  911. const void *ptr = fw->data;
  912. char rsn[64];
  913. u16 lens[5];
  914. size_t len;
  915. unsigned int a, lenp, lencnt;
  916. int ret = -EINVAL;
  917. struct {
  918. __le32 magic; /* 0x34303430 */
  919. u8 reserved1[2];
  920. u8 type; /* UNIX = 3 */
  921. u8 model; /* C218T=1, C320T=2, CP204=3 */
  922. u8 reserved2[8];
  923. __le16 len[5];
  924. } const *hdr = ptr;
  925. BUILD_BUG_ON(ARRAY_SIZE(hdr->len) != ARRAY_SIZE(lens));
  926. if (fw->size < MOXA_FW_HDRLEN) {
  927. strcpy(rsn, "too short (even header won't fit)");
  928. goto err;
  929. }
  930. if (hdr->magic != cpu_to_le32(0x30343034)) {
  931. sprintf(rsn, "bad magic: %.8x", le32_to_cpu(hdr->magic));
  932. goto err;
  933. }
  934. if (hdr->type != 3) {
  935. sprintf(rsn, "not for linux, type is %u", hdr->type);
  936. goto err;
  937. }
  938. if (moxa_check_fw_model(brd, hdr->model)) {
  939. sprintf(rsn, "not for this card, model is %u", hdr->model);
  940. goto err;
  941. }
  942. len = MOXA_FW_HDRLEN;
  943. lencnt = hdr->model == 2 ? 5 : 3;
  944. for (a = 0; a < ARRAY_SIZE(lens); a++) {
  945. lens[a] = le16_to_cpu(hdr->len[a]);
  946. if (lens[a] && len + lens[a] <= fw->size &&
  947. moxa_check_fw(&fw->data[len]))
  948. printk(KERN_WARNING "MOXA firmware: unexpected input "
  949. "at offset %u, but going on\n", (u32)len);
  950. if (!lens[a] && a < lencnt) {
  951. sprintf(rsn, "too few entries in fw file");
  952. goto err;
  953. }
  954. len += lens[a];
  955. }
  956. if (len != fw->size) {
  957. sprintf(rsn, "bad length: %u (should be %u)", (u32)fw->size,
  958. (u32)len);
  959. goto err;
  960. }
  961. ptr += MOXA_FW_HDRLEN;
  962. lenp = 0; /* bios */
  963. strcpy(rsn, "read above");
  964. ret = moxa_load_bios(brd, ptr, lens[lenp]);
  965. if (ret)
  966. goto err;
  967. /* we skip the tty section (lens[1]), since we don't need it */
  968. ptr += lens[lenp] + lens[lenp + 1];
  969. lenp += 2; /* comm */
  970. if (hdr->model == 2) {
  971. ret = moxa_load_320b(brd, ptr, lens[lenp]);
  972. if (ret)
  973. goto err;
  974. /* skip another tty */
  975. ptr += lens[lenp] + lens[lenp + 1];
  976. lenp += 2;
  977. }
  978. ret = moxa_load_code(brd, ptr, lens[lenp]);
  979. if (ret)
  980. goto err;
  981. return 0;
  982. err:
  983. printk(KERN_ERR "firmware failed to load, reason: %s\n", rsn);
  984. return ret;
  985. }
  986. static int moxa_init_board(struct moxa_board_conf *brd, struct device *dev)
  987. {
  988. const struct firmware *fw;
  989. const char *file;
  990. struct moxa_port *p;
  991. unsigned int i, first_idx;
  992. int ret;
  993. brd->ports = kcalloc(MAX_PORTS_PER_BOARD, sizeof(*brd->ports),
  994. GFP_KERNEL);
  995. if (brd->ports == NULL) {
  996. printk(KERN_ERR "cannot allocate memory for ports\n");
  997. ret = -ENOMEM;
  998. goto err;
  999. }
  1000. for (i = 0, p = brd->ports; i < MAX_PORTS_PER_BOARD; i++, p++) {
  1001. tty_port_init(&p->port);
  1002. p->port.ops = &moxa_port_ops;
  1003. p->type = PORT_16550A;
  1004. p->cflag = B9600 | CS8 | CREAD | CLOCAL | HUPCL;
  1005. }
  1006. switch (brd->boardType) {
  1007. case MOXA_BOARD_C218_ISA:
  1008. case MOXA_BOARD_C218_PCI:
  1009. file = "c218tunx.cod";
  1010. break;
  1011. case MOXA_BOARD_CP204J:
  1012. file = "cp204unx.cod";
  1013. break;
  1014. default:
  1015. file = "c320tunx.cod";
  1016. break;
  1017. }
  1018. ret = request_firmware(&fw, file, dev);
  1019. if (ret) {
  1020. printk(KERN_ERR "MOXA: request_firmware failed. Make sure "
  1021. "you've placed '%s' file into your firmware "
  1022. "loader directory (e.g. /lib/firmware)\n",
  1023. file);
  1024. goto err_free;
  1025. }
  1026. ret = moxa_load_fw(brd, fw);
  1027. release_firmware(fw);
  1028. if (ret)
  1029. goto err_free;
  1030. spin_lock_bh(&moxa_lock);
  1031. brd->ready = 1;
  1032. if (!timer_pending(&moxaTimer))
  1033. mod_timer(&moxaTimer, jiffies + HZ / 50);
  1034. spin_unlock_bh(&moxa_lock);
  1035. first_idx = (brd - moxa_boards) * MAX_PORTS_PER_BOARD;
  1036. for (i = 0; i < brd->numPorts; i++)
  1037. tty_port_register_device(&brd->ports[i].port, moxaDriver,
  1038. first_idx + i, dev);
  1039. return 0;
  1040. err_free:
  1041. for (i = 0; i < MAX_PORTS_PER_BOARD; i++)
  1042. tty_port_destroy(&brd->ports[i].port);
  1043. kfree(brd->ports);
  1044. err:
  1045. return ret;
  1046. }
  1047. static void moxa_board_deinit(struct moxa_board_conf *brd)
  1048. {
  1049. unsigned int a, opened, first_idx;
  1050. mutex_lock(&moxa_openlock);
  1051. spin_lock_bh(&moxa_lock);
  1052. brd->ready = 0;
  1053. spin_unlock_bh(&moxa_lock);
  1054. /* pci hot-un-plug support */
  1055. for (a = 0; a < brd->numPorts; a++)
  1056. if (tty_port_initialized(&brd->ports[a].port))
  1057. tty_port_tty_hangup(&brd->ports[a].port, false);
  1058. for (a = 0; a < MAX_PORTS_PER_BOARD; a++)
  1059. tty_port_destroy(&brd->ports[a].port);
  1060. while (1) {
  1061. opened = 0;
  1062. for (a = 0; a < brd->numPorts; a++)
  1063. if (tty_port_initialized(&brd->ports[a].port))
  1064. opened++;
  1065. mutex_unlock(&moxa_openlock);
  1066. if (!opened)
  1067. break;
  1068. msleep(50);
  1069. mutex_lock(&moxa_openlock);
  1070. }
  1071. first_idx = (brd - moxa_boards) * MAX_PORTS_PER_BOARD;
  1072. for (a = 0; a < brd->numPorts; a++)
  1073. tty_unregister_device(moxaDriver, first_idx + a);
  1074. iounmap(brd->basemem);
  1075. brd->basemem = NULL;
  1076. kfree(brd->ports);
  1077. }
  1078. #ifdef CONFIG_PCI
  1079. static int moxa_pci_probe(struct pci_dev *pdev,
  1080. const struct pci_device_id *ent)
  1081. {
  1082. struct moxa_board_conf *board;
  1083. unsigned int i;
  1084. int board_type = ent->driver_data;
  1085. int retval;
  1086. retval = pci_enable_device(pdev);
  1087. if (retval) {
  1088. dev_err(&pdev->dev, "can't enable pci device\n");
  1089. goto err;
  1090. }
  1091. for (i = 0; i < MAX_BOARDS; i++)
  1092. if (moxa_boards[i].basemem == NULL)
  1093. break;
  1094. retval = -ENODEV;
  1095. if (i >= MAX_BOARDS) {
  1096. dev_warn(&pdev->dev, "more than %u MOXA Intellio family boards "
  1097. "found. Board is ignored.\n", MAX_BOARDS);
  1098. goto err;
  1099. }
  1100. board = &moxa_boards[i];
  1101. retval = pci_request_region(pdev, 2, "moxa-base");
  1102. if (retval) {
  1103. dev_err(&pdev->dev, "can't request pci region 2\n");
  1104. goto err;
  1105. }
  1106. board->basemem = ioremap(pci_resource_start(pdev, 2), 0x4000);
  1107. if (board->basemem == NULL) {
  1108. dev_err(&pdev->dev, "can't remap io space 2\n");
  1109. retval = -ENOMEM;
  1110. goto err_reg;
  1111. }
  1112. board->boardType = board_type;
  1113. switch (board_type) {
  1114. case MOXA_BOARD_C218_ISA:
  1115. case MOXA_BOARD_C218_PCI:
  1116. board->numPorts = 8;
  1117. break;
  1118. case MOXA_BOARD_CP204J:
  1119. board->numPorts = 4;
  1120. break;
  1121. default:
  1122. board->numPorts = 0;
  1123. break;
  1124. }
  1125. board->busType = MOXA_BUS_TYPE_PCI;
  1126. retval = moxa_init_board(board, &pdev->dev);
  1127. if (retval)
  1128. goto err_base;
  1129. pci_set_drvdata(pdev, board);
  1130. dev_info(&pdev->dev, "board '%s' ready (%u ports, firmware loaded)\n",
  1131. moxa_brdname[board_type - 1], board->numPorts);
  1132. return 0;
  1133. err_base:
  1134. iounmap(board->basemem);
  1135. board->basemem = NULL;
  1136. err_reg:
  1137. pci_release_region(pdev, 2);
  1138. err:
  1139. return retval;
  1140. }
  1141. static void moxa_pci_remove(struct pci_dev *pdev)
  1142. {
  1143. struct moxa_board_conf *brd = pci_get_drvdata(pdev);
  1144. moxa_board_deinit(brd);
  1145. pci_release_region(pdev, 2);
  1146. }
  1147. static struct pci_driver moxa_pci_driver = {
  1148. .name = "moxa",
  1149. .id_table = moxa_pcibrds,
  1150. .probe = moxa_pci_probe,
  1151. .remove = moxa_pci_remove
  1152. };
  1153. #endif /* CONFIG_PCI */
  1154. static int __init moxa_init(void)
  1155. {
  1156. unsigned int isabrds = 0;
  1157. int retval = 0;
  1158. struct moxa_board_conf *brd = moxa_boards;
  1159. unsigned int i;
  1160. printk(KERN_INFO "MOXA Intellio family driver version %s\n",
  1161. MOXA_VERSION);
  1162. tty_port_init(&moxa_service_port);
  1163. moxaDriver = tty_alloc_driver(MAX_PORTS + 1,
  1164. TTY_DRIVER_REAL_RAW |
  1165. TTY_DRIVER_DYNAMIC_DEV);
  1166. if (IS_ERR(moxaDriver))
  1167. return PTR_ERR(moxaDriver);
  1168. moxaDriver->name = "ttyMX";
  1169. moxaDriver->major = ttymajor;
  1170. moxaDriver->minor_start = 0;
  1171. moxaDriver->type = TTY_DRIVER_TYPE_SERIAL;
  1172. moxaDriver->subtype = SERIAL_TYPE_NORMAL;
  1173. moxaDriver->init_termios = tty_std_termios;
  1174. moxaDriver->init_termios.c_cflag = B9600 | CS8 | CREAD | CLOCAL | HUPCL;
  1175. moxaDriver->init_termios.c_ispeed = 9600;
  1176. moxaDriver->init_termios.c_ospeed = 9600;
  1177. tty_set_operations(moxaDriver, &moxa_ops);
  1178. /* Having one more port only for ioctls is ugly */
  1179. tty_port_link_device(&moxa_service_port, moxaDriver, MAX_PORTS);
  1180. if (tty_register_driver(moxaDriver)) {
  1181. printk(KERN_ERR "can't register MOXA Smartio tty driver!\n");
  1182. tty_driver_kref_put(moxaDriver);
  1183. return -1;
  1184. }
  1185. /* Find the boards defined from module args. */
  1186. for (i = 0; i < MAX_BOARDS; i++) {
  1187. if (!baseaddr[i])
  1188. break;
  1189. if (type[i] == MOXA_BOARD_C218_ISA ||
  1190. type[i] == MOXA_BOARD_C320_ISA) {
  1191. pr_debug("Moxa board %2d: %s board(baseAddr=%lx)\n",
  1192. isabrds + 1, moxa_brdname[type[i] - 1],
  1193. baseaddr[i]);
  1194. brd->boardType = type[i];
  1195. brd->numPorts = type[i] == MOXA_BOARD_C218_ISA ? 8 :
  1196. numports[i];
  1197. brd->busType = MOXA_BUS_TYPE_ISA;
  1198. brd->basemem = ioremap(baseaddr[i], 0x4000);
  1199. if (!brd->basemem) {
  1200. printk(KERN_ERR "MOXA: can't remap %lx\n",
  1201. baseaddr[i]);
  1202. continue;
  1203. }
  1204. if (moxa_init_board(brd, NULL)) {
  1205. iounmap(brd->basemem);
  1206. brd->basemem = NULL;
  1207. continue;
  1208. }
  1209. printk(KERN_INFO "MOXA isa board found at 0x%.8lx and "
  1210. "ready (%u ports, firmware loaded)\n",
  1211. baseaddr[i], brd->numPorts);
  1212. brd++;
  1213. isabrds++;
  1214. }
  1215. }
  1216. #ifdef CONFIG_PCI
  1217. retval = pci_register_driver(&moxa_pci_driver);
  1218. if (retval) {
  1219. printk(KERN_ERR "Can't register MOXA pci driver!\n");
  1220. if (isabrds)
  1221. retval = 0;
  1222. }
  1223. #endif
  1224. return retval;
  1225. }
  1226. static void __exit moxa_exit(void)
  1227. {
  1228. unsigned int i;
  1229. #ifdef CONFIG_PCI
  1230. pci_unregister_driver(&moxa_pci_driver);
  1231. #endif
  1232. for (i = 0; i < MAX_BOARDS; i++) /* ISA boards */
  1233. if (moxa_boards[i].ready)
  1234. moxa_board_deinit(&moxa_boards[i]);
  1235. del_timer_sync(&moxaTimer);
  1236. tty_unregister_driver(moxaDriver);
  1237. tty_driver_kref_put(moxaDriver);
  1238. }
  1239. module_init(moxa_init);
  1240. module_exit(moxa_exit);
  1241. static void moxa_shutdown(struct tty_port *port)
  1242. {
  1243. struct moxa_port *ch = container_of(port, struct moxa_port, port);
  1244. MoxaPortDisable(ch);
  1245. MoxaPortFlushData(ch, 2);
  1246. }
  1247. static int moxa_carrier_raised(struct tty_port *port)
  1248. {
  1249. struct moxa_port *ch = container_of(port, struct moxa_port, port);
  1250. int dcd;
  1251. spin_lock_irq(&port->lock);
  1252. dcd = ch->DCDState;
  1253. spin_unlock_irq(&port->lock);
  1254. return dcd;
  1255. }
  1256. static void moxa_dtr_rts(struct tty_port *port, int onoff)
  1257. {
  1258. struct moxa_port *ch = container_of(port, struct moxa_port, port);
  1259. MoxaPortLineCtrl(ch, onoff, onoff);
  1260. }
  1261. static int moxa_open(struct tty_struct *tty, struct file *filp)
  1262. {
  1263. struct moxa_board_conf *brd;
  1264. struct moxa_port *ch;
  1265. int port;
  1266. port = tty->index;
  1267. if (port == MAX_PORTS) {
  1268. return capable(CAP_SYS_ADMIN) ? 0 : -EPERM;
  1269. }
  1270. if (mutex_lock_interruptible(&moxa_openlock))
  1271. return -ERESTARTSYS;
  1272. brd = &moxa_boards[port / MAX_PORTS_PER_BOARD];
  1273. if (!brd->ready) {
  1274. mutex_unlock(&moxa_openlock);
  1275. return -ENODEV;
  1276. }
  1277. if (port % MAX_PORTS_PER_BOARD >= brd->numPorts) {
  1278. mutex_unlock(&moxa_openlock);
  1279. return -ENODEV;
  1280. }
  1281. ch = &brd->ports[port % MAX_PORTS_PER_BOARD];
  1282. ch->port.count++;
  1283. tty->driver_data = ch;
  1284. tty_port_tty_set(&ch->port, tty);
  1285. mutex_lock(&ch->port.mutex);
  1286. if (!tty_port_initialized(&ch->port)) {
  1287. ch->statusflags = 0;
  1288. moxa_set_tty_param(tty, &tty->termios);
  1289. MoxaPortLineCtrl(ch, 1, 1);
  1290. MoxaPortEnable(ch);
  1291. MoxaSetFifo(ch, ch->type == PORT_16550A);
  1292. tty_port_set_initialized(&ch->port, 1);
  1293. }
  1294. mutex_unlock(&ch->port.mutex);
  1295. mutex_unlock(&moxa_openlock);
  1296. return tty_port_block_til_ready(&ch->port, tty, filp);
  1297. }
  1298. static void moxa_close(struct tty_struct *tty, struct file *filp)
  1299. {
  1300. struct moxa_port *ch = tty->driver_data;
  1301. ch->cflag = tty->termios.c_cflag;
  1302. tty_port_close(&ch->port, tty, filp);
  1303. }
  1304. static int moxa_write(struct tty_struct *tty,
  1305. const unsigned char *buf, int count)
  1306. {
  1307. struct moxa_port *ch = tty->driver_data;
  1308. unsigned long flags;
  1309. int len;
  1310. if (ch == NULL)
  1311. return 0;
  1312. spin_lock_irqsave(&moxa_lock, flags);
  1313. len = MoxaPortWriteData(tty, buf, count);
  1314. spin_unlock_irqrestore(&moxa_lock, flags);
  1315. set_bit(LOWWAIT, &ch->statusflags);
  1316. return len;
  1317. }
  1318. static unsigned int moxa_write_room(struct tty_struct *tty)
  1319. {
  1320. struct moxa_port *ch;
  1321. if (tty->flow.stopped)
  1322. return 0;
  1323. ch = tty->driver_data;
  1324. if (ch == NULL)
  1325. return 0;
  1326. return MoxaPortTxFree(ch);
  1327. }
  1328. static void moxa_flush_buffer(struct tty_struct *tty)
  1329. {
  1330. struct moxa_port *ch = tty->driver_data;
  1331. if (ch == NULL)
  1332. return;
  1333. MoxaPortFlushData(ch, 1);
  1334. tty_wakeup(tty);
  1335. }
  1336. static unsigned int moxa_chars_in_buffer(struct tty_struct *tty)
  1337. {
  1338. struct moxa_port *ch = tty->driver_data;
  1339. unsigned int chars;
  1340. chars = MoxaPortTxQueue(ch);
  1341. if (chars)
  1342. /*
  1343. * Make it possible to wakeup anything waiting for output
  1344. * in tty_ioctl.c, etc.
  1345. */
  1346. set_bit(EMPTYWAIT, &ch->statusflags);
  1347. return chars;
  1348. }
  1349. static int moxa_tiocmget(struct tty_struct *tty)
  1350. {
  1351. struct moxa_port *ch = tty->driver_data;
  1352. int flag = 0, dtr, rts;
  1353. MoxaPortGetLineOut(ch, &dtr, &rts);
  1354. if (dtr)
  1355. flag |= TIOCM_DTR;
  1356. if (rts)
  1357. flag |= TIOCM_RTS;
  1358. dtr = MoxaPortLineStatus(ch);
  1359. if (dtr & 1)
  1360. flag |= TIOCM_CTS;
  1361. if (dtr & 2)
  1362. flag |= TIOCM_DSR;
  1363. if (dtr & 4)
  1364. flag |= TIOCM_CD;
  1365. return flag;
  1366. }
  1367. static int moxa_tiocmset(struct tty_struct *tty,
  1368. unsigned int set, unsigned int clear)
  1369. {
  1370. struct moxa_port *ch;
  1371. int dtr, rts;
  1372. mutex_lock(&moxa_openlock);
  1373. ch = tty->driver_data;
  1374. if (!ch) {
  1375. mutex_unlock(&moxa_openlock);
  1376. return -EINVAL;
  1377. }
  1378. MoxaPortGetLineOut(ch, &dtr, &rts);
  1379. if (set & TIOCM_RTS)
  1380. rts = 1;
  1381. if (set & TIOCM_DTR)
  1382. dtr = 1;
  1383. if (clear & TIOCM_RTS)
  1384. rts = 0;
  1385. if (clear & TIOCM_DTR)
  1386. dtr = 0;
  1387. MoxaPortLineCtrl(ch, dtr, rts);
  1388. mutex_unlock(&moxa_openlock);
  1389. return 0;
  1390. }
  1391. static void moxa_set_termios(struct tty_struct *tty,
  1392. const struct ktermios *old_termios)
  1393. {
  1394. struct moxa_port *ch = tty->driver_data;
  1395. if (ch == NULL)
  1396. return;
  1397. moxa_set_tty_param(tty, old_termios);
  1398. if (!(old_termios->c_cflag & CLOCAL) && C_CLOCAL(tty))
  1399. wake_up_interruptible(&ch->port.open_wait);
  1400. }
  1401. static void moxa_stop(struct tty_struct *tty)
  1402. {
  1403. struct moxa_port *ch = tty->driver_data;
  1404. if (ch == NULL)
  1405. return;
  1406. MoxaPortTxDisable(ch);
  1407. set_bit(TXSTOPPED, &ch->statusflags);
  1408. }
  1409. static void moxa_start(struct tty_struct *tty)
  1410. {
  1411. struct moxa_port *ch = tty->driver_data;
  1412. if (ch == NULL)
  1413. return;
  1414. if (!test_bit(TXSTOPPED, &ch->statusflags))
  1415. return;
  1416. MoxaPortTxEnable(ch);
  1417. clear_bit(TXSTOPPED, &ch->statusflags);
  1418. }
  1419. static void moxa_hangup(struct tty_struct *tty)
  1420. {
  1421. struct moxa_port *ch = tty->driver_data;
  1422. tty_port_hangup(&ch->port);
  1423. }
  1424. static void moxa_new_dcdstate(struct moxa_port *p, u8 dcd)
  1425. {
  1426. unsigned long flags;
  1427. dcd = !!dcd;
  1428. spin_lock_irqsave(&p->port.lock, flags);
  1429. if (dcd != p->DCDState) {
  1430. p->DCDState = dcd;
  1431. spin_unlock_irqrestore(&p->port.lock, flags);
  1432. if (!dcd)
  1433. tty_port_tty_hangup(&p->port, true);
  1434. }
  1435. else
  1436. spin_unlock_irqrestore(&p->port.lock, flags);
  1437. }
  1438. static int moxa_poll_port(struct moxa_port *p, unsigned int handle,
  1439. u16 __iomem *ip)
  1440. {
  1441. struct tty_struct *tty = tty_port_tty_get(&p->port);
  1442. void __iomem *ofsAddr;
  1443. unsigned int inited = tty_port_initialized(&p->port);
  1444. u16 intr;
  1445. if (tty) {
  1446. if (test_bit(EMPTYWAIT, &p->statusflags) &&
  1447. MoxaPortTxQueue(p) == 0) {
  1448. clear_bit(EMPTYWAIT, &p->statusflags);
  1449. tty_wakeup(tty);
  1450. }
  1451. if (test_bit(LOWWAIT, &p->statusflags) && !tty->flow.stopped &&
  1452. MoxaPortTxQueue(p) <= WAKEUP_CHARS) {
  1453. clear_bit(LOWWAIT, &p->statusflags);
  1454. tty_wakeup(tty);
  1455. }
  1456. if (inited && !tty_throttled(tty) &&
  1457. MoxaPortRxQueue(p) > 0) { /* RX */
  1458. MoxaPortReadData(p);
  1459. tty_flip_buffer_push(&p->port);
  1460. }
  1461. } else {
  1462. clear_bit(EMPTYWAIT, &p->statusflags);
  1463. MoxaPortFlushData(p, 0); /* flush RX */
  1464. }
  1465. if (!handle) /* nothing else to do */
  1466. goto put;
  1467. intr = readw(ip); /* port irq status */
  1468. if (intr == 0)
  1469. goto put;
  1470. writew(0, ip); /* ACK port */
  1471. ofsAddr = p->tableAddr;
  1472. if (intr & IntrTx) /* disable tx intr */
  1473. writew(readw(ofsAddr + HostStat) & ~WakeupTx,
  1474. ofsAddr + HostStat);
  1475. if (!inited)
  1476. goto put;
  1477. if (tty && (intr & IntrBreak) && !I_IGNBRK(tty)) { /* BREAK */
  1478. tty_insert_flip_char(&p->port, 0, TTY_BREAK);
  1479. tty_flip_buffer_push(&p->port);
  1480. }
  1481. if (intr & IntrLine)
  1482. moxa_new_dcdstate(p, readb(ofsAddr + FlagStat) & DCD_state);
  1483. put:
  1484. tty_kref_put(tty);
  1485. return 0;
  1486. }
  1487. static void moxa_poll(struct timer_list *unused)
  1488. {
  1489. struct moxa_board_conf *brd;
  1490. u16 __iomem *ip;
  1491. unsigned int card, port, served = 0;
  1492. spin_lock(&moxa_lock);
  1493. for (card = 0; card < MAX_BOARDS; card++) {
  1494. brd = &moxa_boards[card];
  1495. if (!brd->ready)
  1496. continue;
  1497. served++;
  1498. ip = NULL;
  1499. if (readb(brd->intPend) == 0xff)
  1500. ip = brd->intTable + readb(brd->intNdx);
  1501. for (port = 0; port < brd->numPorts; port++)
  1502. moxa_poll_port(&brd->ports[port], !!ip, ip + port);
  1503. if (ip)
  1504. writeb(0, brd->intPend); /* ACK */
  1505. if (moxaLowWaterChk) {
  1506. struct moxa_port *p = brd->ports;
  1507. for (port = 0; port < brd->numPorts; port++, p++)
  1508. if (p->lowChkFlag) {
  1509. p->lowChkFlag = 0;
  1510. moxa_low_water_check(p->tableAddr);
  1511. }
  1512. }
  1513. }
  1514. moxaLowWaterChk = 0;
  1515. if (served)
  1516. mod_timer(&moxaTimer, jiffies + HZ / 50);
  1517. spin_unlock(&moxa_lock);
  1518. }
  1519. /******************************************************************************/
  1520. static void moxa_set_tty_param(struct tty_struct *tty,
  1521. const struct ktermios *old_termios)
  1522. {
  1523. register struct ktermios *ts = &tty->termios;
  1524. struct moxa_port *ch = tty->driver_data;
  1525. int rts, cts, txflow, rxflow, xany, baud;
  1526. rts = cts = txflow = rxflow = xany = 0;
  1527. if (ts->c_cflag & CRTSCTS)
  1528. rts = cts = 1;
  1529. if (ts->c_iflag & IXON)
  1530. txflow = 1;
  1531. if (ts->c_iflag & IXOFF)
  1532. rxflow = 1;
  1533. if (ts->c_iflag & IXANY)
  1534. xany = 1;
  1535. MoxaPortFlowCtrl(ch, rts, cts, txflow, rxflow, xany);
  1536. baud = MoxaPortSetTermio(ch, ts, tty_get_baud_rate(tty));
  1537. if (baud == -1)
  1538. baud = tty_termios_baud_rate(old_termios);
  1539. /* Not put the baud rate into the termios data */
  1540. tty_encode_baud_rate(tty, baud, baud);
  1541. }
  1542. /*****************************************************************************
  1543. * Driver level functions: *
  1544. *****************************************************************************/
  1545. static void MoxaPortFlushData(struct moxa_port *port, int mode)
  1546. {
  1547. void __iomem *ofsAddr;
  1548. if (mode < 0 || mode > 2)
  1549. return;
  1550. ofsAddr = port->tableAddr;
  1551. moxafunc(ofsAddr, FC_FlushQueue, mode);
  1552. if (mode != 1) {
  1553. port->lowChkFlag = 0;
  1554. moxa_low_water_check(ofsAddr);
  1555. }
  1556. }
  1557. /*
  1558. * Moxa Port Number Description:
  1559. *
  1560. * MOXA serial driver supports up to 4 MOXA-C218/C320 boards. And,
  1561. * the port number using in MOXA driver functions will be 0 to 31 for
  1562. * first MOXA board, 32 to 63 for second, 64 to 95 for third and 96
  1563. * to 127 for fourth. For example, if you setup three MOXA boards,
  1564. * first board is C218, second board is C320-16 and third board is
  1565. * C320-32. The port number of first board (C218 - 8 ports) is from
  1566. * 0 to 7. The port number of second board (C320 - 16 ports) is form
  1567. * 32 to 47. The port number of third board (C320 - 32 ports) is from
  1568. * 64 to 95. And those port numbers form 8 to 31, 48 to 63 and 96 to
  1569. * 127 will be invalid.
  1570. *
  1571. *
  1572. * Moxa Functions Description:
  1573. *
  1574. * Function 1: Driver initialization routine, this routine must be
  1575. * called when initialized driver.
  1576. * Syntax:
  1577. * void MoxaDriverInit();
  1578. *
  1579. *
  1580. * Function 2: Moxa driver private IOCTL command processing.
  1581. * Syntax:
  1582. * int MoxaDriverIoctl(unsigned int cmd, unsigned long arg, int port);
  1583. *
  1584. * unsigned int cmd : IOCTL command
  1585. * unsigned long arg : IOCTL argument
  1586. * int port : port number (0 - 127)
  1587. *
  1588. * return: 0 (OK)
  1589. * -EINVAL
  1590. * -ENOIOCTLCMD
  1591. *
  1592. *
  1593. * Function 6: Enable this port to start Tx/Rx data.
  1594. * Syntax:
  1595. * void MoxaPortEnable(int port);
  1596. * int port : port number (0 - 127)
  1597. *
  1598. *
  1599. * Function 7: Disable this port
  1600. * Syntax:
  1601. * void MoxaPortDisable(int port);
  1602. * int port : port number (0 - 127)
  1603. *
  1604. *
  1605. * Function 10: Setting baud rate of this port.
  1606. * Syntax:
  1607. * speed_t MoxaPortSetBaud(int port, speed_t baud);
  1608. * int port : port number (0 - 127)
  1609. * long baud : baud rate (50 - 115200)
  1610. *
  1611. * return: 0 : this port is invalid or baud < 50
  1612. * 50 - 115200 : the real baud rate set to the port, if
  1613. * the argument baud is large than maximun
  1614. * available baud rate, the real setting
  1615. * baud rate will be the maximun baud rate.
  1616. *
  1617. *
  1618. * Function 12: Configure the port.
  1619. * Syntax:
  1620. * int MoxaPortSetTermio(int port, struct ktermios *termio, speed_t baud);
  1621. * int port : port number (0 - 127)
  1622. * struct ktermios * termio : termio structure pointer
  1623. * speed_t baud : baud rate
  1624. *
  1625. * return: -1 : this port is invalid or termio == NULL
  1626. * 0 : setting O.K.
  1627. *
  1628. *
  1629. * Function 13: Get the DTR/RTS state of this port.
  1630. * Syntax:
  1631. * int MoxaPortGetLineOut(int port, int *dtrState, int *rtsState);
  1632. * int port : port number (0 - 127)
  1633. * int * dtrState : pointer to INT to receive the current DTR
  1634. * state. (if NULL, this function will not
  1635. * write to this address)
  1636. * int * rtsState : pointer to INT to receive the current RTS
  1637. * state. (if NULL, this function will not
  1638. * write to this address)
  1639. *
  1640. * return: -1 : this port is invalid
  1641. * 0 : O.K.
  1642. *
  1643. *
  1644. * Function 14: Setting the DTR/RTS output state of this port.
  1645. * Syntax:
  1646. * void MoxaPortLineCtrl(int port, int dtrState, int rtsState);
  1647. * int port : port number (0 - 127)
  1648. * int dtrState : DTR output state (0: off, 1: on)
  1649. * int rtsState : RTS output state (0: off, 1: on)
  1650. *
  1651. *
  1652. * Function 15: Setting the flow control of this port.
  1653. * Syntax:
  1654. * void MoxaPortFlowCtrl(int port, int rtsFlow, int ctsFlow, int rxFlow,
  1655. * int txFlow,int xany);
  1656. * int port : port number (0 - 127)
  1657. * int rtsFlow : H/W RTS flow control (0: no, 1: yes)
  1658. * int ctsFlow : H/W CTS flow control (0: no, 1: yes)
  1659. * int rxFlow : S/W Rx XON/XOFF flow control (0: no, 1: yes)
  1660. * int txFlow : S/W Tx XON/XOFF flow control (0: no, 1: yes)
  1661. * int xany : S/W XANY flow control (0: no, 1: yes)
  1662. *
  1663. *
  1664. * Function 16: Get ths line status of this port
  1665. * Syntax:
  1666. * int MoxaPortLineStatus(int port);
  1667. * int port : port number (0 - 127)
  1668. *
  1669. * return: Bit 0 - CTS state (0: off, 1: on)
  1670. * Bit 1 - DSR state (0: off, 1: on)
  1671. * Bit 2 - DCD state (0: off, 1: on)
  1672. *
  1673. *
  1674. * Function 19: Flush the Rx/Tx buffer data of this port.
  1675. * Syntax:
  1676. * void MoxaPortFlushData(int port, int mode);
  1677. * int port : port number (0 - 127)
  1678. * int mode
  1679. * 0 : flush the Rx buffer
  1680. * 1 : flush the Tx buffer
  1681. * 2 : flush the Rx and Tx buffer
  1682. *
  1683. *
  1684. * Function 20: Write data.
  1685. * Syntax:
  1686. * int MoxaPortWriteData(int port, unsigned char * buffer, int length);
  1687. * int port : port number (0 - 127)
  1688. * unsigned char * buffer : pointer to write data buffer.
  1689. * int length : write data length
  1690. *
  1691. * return: 0 - length : real write data length
  1692. *
  1693. *
  1694. * Function 21: Read data.
  1695. * Syntax:
  1696. * int MoxaPortReadData(int port, struct tty_struct *tty);
  1697. * int port : port number (0 - 127)
  1698. * struct tty_struct *tty : tty for data
  1699. *
  1700. * return: 0 - length : real read data length
  1701. *
  1702. *
  1703. * Function 24: Get the Tx buffer current queued data bytes
  1704. * Syntax:
  1705. * int MoxaPortTxQueue(int port);
  1706. * int port : port number (0 - 127)
  1707. *
  1708. * return: .. : Tx buffer current queued data bytes
  1709. *
  1710. *
  1711. * Function 25: Get the Tx buffer current free space
  1712. * Syntax:
  1713. * int MoxaPortTxFree(int port);
  1714. * int port : port number (0 - 127)
  1715. *
  1716. * return: .. : Tx buffer current free space
  1717. *
  1718. *
  1719. * Function 26: Get the Rx buffer current queued data bytes
  1720. * Syntax:
  1721. * int MoxaPortRxQueue(int port);
  1722. * int port : port number (0 - 127)
  1723. *
  1724. * return: .. : Rx buffer current queued data bytes
  1725. *
  1726. *
  1727. * Function 28: Disable port data transmission.
  1728. * Syntax:
  1729. * void MoxaPortTxDisable(int port);
  1730. * int port : port number (0 - 127)
  1731. *
  1732. *
  1733. * Function 29: Enable port data transmission.
  1734. * Syntax:
  1735. * void MoxaPortTxEnable(int port);
  1736. * int port : port number (0 - 127)
  1737. *
  1738. *
  1739. * Function 31: Get the received BREAK signal count and reset it.
  1740. * Syntax:
  1741. * int MoxaPortResetBrkCnt(int port);
  1742. * int port : port number (0 - 127)
  1743. *
  1744. * return: 0 - .. : BREAK signal count
  1745. *
  1746. *
  1747. */
  1748. static void MoxaPortEnable(struct moxa_port *port)
  1749. {
  1750. void __iomem *ofsAddr;
  1751. u16 lowwater = 512;
  1752. ofsAddr = port->tableAddr;
  1753. writew(lowwater, ofsAddr + Low_water);
  1754. if (MOXA_IS_320(port->board))
  1755. moxafunc(ofsAddr, FC_SetBreakIrq, 0);
  1756. else
  1757. writew(readw(ofsAddr + HostStat) | WakeupBreak,
  1758. ofsAddr + HostStat);
  1759. moxafunc(ofsAddr, FC_SetLineIrq, Magic_code);
  1760. moxafunc(ofsAddr, FC_FlushQueue, 2);
  1761. moxafunc(ofsAddr, FC_EnableCH, Magic_code);
  1762. MoxaPortLineStatus(port);
  1763. }
  1764. static void MoxaPortDisable(struct moxa_port *port)
  1765. {
  1766. void __iomem *ofsAddr = port->tableAddr;
  1767. moxafunc(ofsAddr, FC_SetFlowCtl, 0); /* disable flow control */
  1768. moxafunc(ofsAddr, FC_ClrLineIrq, Magic_code);
  1769. writew(0, ofsAddr + HostStat);
  1770. moxafunc(ofsAddr, FC_DisableCH, Magic_code);
  1771. }
  1772. static speed_t MoxaPortSetBaud(struct moxa_port *port, speed_t baud)
  1773. {
  1774. void __iomem *ofsAddr = port->tableAddr;
  1775. unsigned int clock, val;
  1776. speed_t max;
  1777. max = MOXA_IS_320(port->board) ? 460800 : 921600;
  1778. if (baud < 50)
  1779. return 0;
  1780. if (baud > max)
  1781. baud = max;
  1782. clock = 921600;
  1783. val = clock / baud;
  1784. moxafunc(ofsAddr, FC_SetBaud, val);
  1785. baud = clock / val;
  1786. return baud;
  1787. }
  1788. static int MoxaPortSetTermio(struct moxa_port *port, struct ktermios *termio,
  1789. speed_t baud)
  1790. {
  1791. void __iomem *ofsAddr;
  1792. tcflag_t mode = 0;
  1793. ofsAddr = port->tableAddr;
  1794. mode = termio->c_cflag & CSIZE;
  1795. if (mode == CS5)
  1796. mode = MX_CS5;
  1797. else if (mode == CS6)
  1798. mode = MX_CS6;
  1799. else if (mode == CS7)
  1800. mode = MX_CS7;
  1801. else if (mode == CS8)
  1802. mode = MX_CS8;
  1803. if (termio->c_cflag & CSTOPB) {
  1804. if (mode == MX_CS5)
  1805. mode |= MX_STOP15;
  1806. else
  1807. mode |= MX_STOP2;
  1808. } else
  1809. mode |= MX_STOP1;
  1810. if (termio->c_cflag & PARENB) {
  1811. if (termio->c_cflag & PARODD) {
  1812. if (termio->c_cflag & CMSPAR)
  1813. mode |= MX_PARMARK;
  1814. else
  1815. mode |= MX_PARODD;
  1816. } else {
  1817. if (termio->c_cflag & CMSPAR)
  1818. mode |= MX_PARSPACE;
  1819. else
  1820. mode |= MX_PAREVEN;
  1821. }
  1822. } else
  1823. mode |= MX_PARNONE;
  1824. moxafunc(ofsAddr, FC_SetDataMode, (u16)mode);
  1825. if (MOXA_IS_320(port->board) && baud >= 921600)
  1826. return -1;
  1827. baud = MoxaPortSetBaud(port, baud);
  1828. if (termio->c_iflag & (IXON | IXOFF | IXANY)) {
  1829. spin_lock_irq(&moxafunc_lock);
  1830. writeb(termio->c_cc[VSTART], ofsAddr + FuncArg);
  1831. writeb(termio->c_cc[VSTOP], ofsAddr + FuncArg1);
  1832. writeb(FC_SetXonXoff, ofsAddr + FuncCode);
  1833. moxa_wait_finish(ofsAddr);
  1834. spin_unlock_irq(&moxafunc_lock);
  1835. }
  1836. return baud;
  1837. }
  1838. static int MoxaPortGetLineOut(struct moxa_port *port, int *dtrState,
  1839. int *rtsState)
  1840. {
  1841. if (dtrState)
  1842. *dtrState = !!(port->lineCtrl & DTR_ON);
  1843. if (rtsState)
  1844. *rtsState = !!(port->lineCtrl & RTS_ON);
  1845. return 0;
  1846. }
  1847. static void MoxaPortLineCtrl(struct moxa_port *port, int dtr, int rts)
  1848. {
  1849. u8 mode = 0;
  1850. if (dtr)
  1851. mode |= DTR_ON;
  1852. if (rts)
  1853. mode |= RTS_ON;
  1854. port->lineCtrl = mode;
  1855. moxafunc(port->tableAddr, FC_LineControl, mode);
  1856. }
  1857. static void MoxaPortFlowCtrl(struct moxa_port *port, int rts, int cts,
  1858. int txflow, int rxflow, int txany)
  1859. {
  1860. int mode = 0;
  1861. if (rts)
  1862. mode |= RTS_FlowCtl;
  1863. if (cts)
  1864. mode |= CTS_FlowCtl;
  1865. if (txflow)
  1866. mode |= Tx_FlowCtl;
  1867. if (rxflow)
  1868. mode |= Rx_FlowCtl;
  1869. if (txany)
  1870. mode |= IXM_IXANY;
  1871. moxafunc(port->tableAddr, FC_SetFlowCtl, mode);
  1872. }
  1873. static int MoxaPortLineStatus(struct moxa_port *port)
  1874. {
  1875. void __iomem *ofsAddr;
  1876. int val;
  1877. ofsAddr = port->tableAddr;
  1878. if (MOXA_IS_320(port->board))
  1879. val = moxafuncret(ofsAddr, FC_LineStatus, 0);
  1880. else
  1881. val = readw(ofsAddr + FlagStat) >> 4;
  1882. val &= 0x0B;
  1883. if (val & 8)
  1884. val |= 4;
  1885. moxa_new_dcdstate(port, val & 8);
  1886. val &= 7;
  1887. return val;
  1888. }
  1889. static int MoxaPortWriteData(struct tty_struct *tty,
  1890. const unsigned char *buffer, int len)
  1891. {
  1892. struct moxa_port *port = tty->driver_data;
  1893. void __iomem *baseAddr, *ofsAddr, *ofs;
  1894. unsigned int c, total;
  1895. u16 head, tail, tx_mask, spage, epage;
  1896. u16 pageno, pageofs, bufhead;
  1897. ofsAddr = port->tableAddr;
  1898. baseAddr = port->board->basemem;
  1899. tx_mask = readw(ofsAddr + TX_mask);
  1900. spage = readw(ofsAddr + Page_txb);
  1901. epage = readw(ofsAddr + EndPage_txb);
  1902. tail = readw(ofsAddr + TXwptr);
  1903. head = readw(ofsAddr + TXrptr);
  1904. c = (head > tail) ? (head - tail - 1) : (head - tail + tx_mask);
  1905. if (c > len)
  1906. c = len;
  1907. moxaLog.txcnt[port->port.tty->index] += c;
  1908. total = c;
  1909. if (spage == epage) {
  1910. bufhead = readw(ofsAddr + Ofs_txb);
  1911. writew(spage, baseAddr + Control_reg);
  1912. while (c > 0) {
  1913. if (head > tail)
  1914. len = head - tail - 1;
  1915. else
  1916. len = tx_mask + 1 - tail;
  1917. len = (c > len) ? len : c;
  1918. ofs = baseAddr + DynPage_addr + bufhead + tail;
  1919. memcpy_toio(ofs, buffer, len);
  1920. buffer += len;
  1921. tail = (tail + len) & tx_mask;
  1922. c -= len;
  1923. }
  1924. } else {
  1925. pageno = spage + (tail >> 13);
  1926. pageofs = tail & Page_mask;
  1927. while (c > 0) {
  1928. len = Page_size - pageofs;
  1929. if (len > c)
  1930. len = c;
  1931. writeb(pageno, baseAddr + Control_reg);
  1932. ofs = baseAddr + DynPage_addr + pageofs;
  1933. memcpy_toio(ofs, buffer, len);
  1934. buffer += len;
  1935. if (++pageno == epage)
  1936. pageno = spage;
  1937. pageofs = 0;
  1938. c -= len;
  1939. }
  1940. tail = (tail + total) & tx_mask;
  1941. }
  1942. writew(tail, ofsAddr + TXwptr);
  1943. writeb(1, ofsAddr + CD180TXirq); /* start to send */
  1944. return total;
  1945. }
  1946. static int MoxaPortReadData(struct moxa_port *port)
  1947. {
  1948. struct tty_struct *tty = port->port.tty;
  1949. unsigned char *dst;
  1950. void __iomem *baseAddr, *ofsAddr, *ofs;
  1951. unsigned int count, len, total;
  1952. u16 tail, rx_mask, spage, epage;
  1953. u16 pageno, pageofs, bufhead, head;
  1954. ofsAddr = port->tableAddr;
  1955. baseAddr = port->board->basemem;
  1956. head = readw(ofsAddr + RXrptr);
  1957. tail = readw(ofsAddr + RXwptr);
  1958. rx_mask = readw(ofsAddr + RX_mask);
  1959. spage = readw(ofsAddr + Page_rxb);
  1960. epage = readw(ofsAddr + EndPage_rxb);
  1961. count = (tail >= head) ? (tail - head) : (tail - head + rx_mask + 1);
  1962. if (count == 0)
  1963. return 0;
  1964. total = count;
  1965. moxaLog.rxcnt[tty->index] += total;
  1966. if (spage == epage) {
  1967. bufhead = readw(ofsAddr + Ofs_rxb);
  1968. writew(spage, baseAddr + Control_reg);
  1969. while (count > 0) {
  1970. ofs = baseAddr + DynPage_addr + bufhead + head;
  1971. len = (tail >= head) ? (tail - head) :
  1972. (rx_mask + 1 - head);
  1973. len = tty_prepare_flip_string(&port->port, &dst,
  1974. min(len, count));
  1975. memcpy_fromio(dst, ofs, len);
  1976. head = (head + len) & rx_mask;
  1977. count -= len;
  1978. }
  1979. } else {
  1980. pageno = spage + (head >> 13);
  1981. pageofs = head & Page_mask;
  1982. while (count > 0) {
  1983. writew(pageno, baseAddr + Control_reg);
  1984. ofs = baseAddr + DynPage_addr + pageofs;
  1985. len = tty_prepare_flip_string(&port->port, &dst,
  1986. min(Page_size - pageofs, count));
  1987. memcpy_fromio(dst, ofs, len);
  1988. count -= len;
  1989. pageofs = (pageofs + len) & Page_mask;
  1990. if (pageofs == 0 && ++pageno == epage)
  1991. pageno = spage;
  1992. }
  1993. head = (head + total) & rx_mask;
  1994. }
  1995. writew(head, ofsAddr + RXrptr);
  1996. if (readb(ofsAddr + FlagStat) & Xoff_state) {
  1997. moxaLowWaterChk = 1;
  1998. port->lowChkFlag = 1;
  1999. }
  2000. return total;
  2001. }
  2002. static unsigned int MoxaPortTxQueue(struct moxa_port *port)
  2003. {
  2004. void __iomem *ofsAddr = port->tableAddr;
  2005. u16 rptr, wptr, mask;
  2006. rptr = readw(ofsAddr + TXrptr);
  2007. wptr = readw(ofsAddr + TXwptr);
  2008. mask = readw(ofsAddr + TX_mask);
  2009. return (wptr - rptr) & mask;
  2010. }
  2011. static unsigned int MoxaPortTxFree(struct moxa_port *port)
  2012. {
  2013. void __iomem *ofsAddr = port->tableAddr;
  2014. u16 rptr, wptr, mask;
  2015. rptr = readw(ofsAddr + TXrptr);
  2016. wptr = readw(ofsAddr + TXwptr);
  2017. mask = readw(ofsAddr + TX_mask);
  2018. return mask - ((wptr - rptr) & mask);
  2019. }
  2020. static int MoxaPortRxQueue(struct moxa_port *port)
  2021. {
  2022. void __iomem *ofsAddr = port->tableAddr;
  2023. u16 rptr, wptr, mask;
  2024. rptr = readw(ofsAddr + RXrptr);
  2025. wptr = readw(ofsAddr + RXwptr);
  2026. mask = readw(ofsAddr + RX_mask);
  2027. return (wptr - rptr) & mask;
  2028. }
  2029. static void MoxaPortTxDisable(struct moxa_port *port)
  2030. {
  2031. moxafunc(port->tableAddr, FC_SetXoffState, Magic_code);
  2032. }
  2033. static void MoxaPortTxEnable(struct moxa_port *port)
  2034. {
  2035. moxafunc(port->tableAddr, FC_SetXonState, Magic_code);
  2036. }
  2037. static int moxa_get_serial_info(struct tty_struct *tty,
  2038. struct serial_struct *ss)
  2039. {
  2040. struct moxa_port *info = tty->driver_data;
  2041. if (tty->index == MAX_PORTS)
  2042. return -EINVAL;
  2043. if (!info)
  2044. return -ENODEV;
  2045. mutex_lock(&info->port.mutex);
  2046. ss->type = info->type;
  2047. ss->line = info->port.tty->index;
  2048. ss->flags = info->port.flags;
  2049. ss->baud_base = 921600;
  2050. ss->close_delay = jiffies_to_msecs(info->port.close_delay) / 10;
  2051. mutex_unlock(&info->port.mutex);
  2052. return 0;
  2053. }
  2054. static int moxa_set_serial_info(struct tty_struct *tty,
  2055. struct serial_struct *ss)
  2056. {
  2057. struct moxa_port *info = tty->driver_data;
  2058. unsigned int close_delay;
  2059. if (tty->index == MAX_PORTS)
  2060. return -EINVAL;
  2061. if (!info)
  2062. return -ENODEV;
  2063. close_delay = msecs_to_jiffies(ss->close_delay * 10);
  2064. mutex_lock(&info->port.mutex);
  2065. if (!capable(CAP_SYS_ADMIN)) {
  2066. if (close_delay != info->port.close_delay ||
  2067. ss->type != info->type ||
  2068. ((ss->flags & ~ASYNC_USR_MASK) !=
  2069. (info->port.flags & ~ASYNC_USR_MASK))) {
  2070. mutex_unlock(&info->port.mutex);
  2071. return -EPERM;
  2072. }
  2073. } else {
  2074. info->port.close_delay = close_delay;
  2075. MoxaSetFifo(info, ss->type == PORT_16550A);
  2076. info->type = ss->type;
  2077. }
  2078. mutex_unlock(&info->port.mutex);
  2079. return 0;
  2080. }
  2081. /*****************************************************************************
  2082. * Static local functions: *
  2083. *****************************************************************************/
  2084. static void MoxaSetFifo(struct moxa_port *port, int enable)
  2085. {
  2086. void __iomem *ofsAddr = port->tableAddr;
  2087. if (!enable) {
  2088. moxafunc(ofsAddr, FC_SetRxFIFOTrig, 0);
  2089. moxafunc(ofsAddr, FC_SetTxFIFOCnt, 1);
  2090. } else {
  2091. moxafunc(ofsAddr, FC_SetRxFIFOTrig, 3);
  2092. moxafunc(ofsAddr, FC_SetTxFIFOCnt, 16);
  2093. }
  2094. }