kcapi.c 30 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301
  1. /* $Id: kcapi.c,v 1.1.2.8 2004/03/26 19:57:20 armin Exp $
  2. *
  3. * Kernel CAPI 2.0 Module
  4. *
  5. * Copyright 1999 by Carsten Paeth <calle@calle.de>
  6. * Copyright 2002 by Kai Germaschewski <kai@germaschewski.name>
  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. */
  12. #define AVMB1_COMPAT
  13. #include "kcapi.h"
  14. #include <linux/module.h>
  15. #include <linux/mm.h>
  16. #include <linux/interrupt.h>
  17. #include <linux/ioport.h>
  18. #include <linux/proc_fs.h>
  19. #include <linux/sched.h>
  20. #include <linux/seq_file.h>
  21. #include <linux/skbuff.h>
  22. #include <linux/workqueue.h>
  23. #include <linux/capi.h>
  24. #include <linux/kernelcapi.h>
  25. #include <linux/init.h>
  26. #include <linux/moduleparam.h>
  27. #include <linux/delay.h>
  28. #include <asm/uaccess.h>
  29. #include <linux/isdn/capicmd.h>
  30. #include <linux/isdn/capiutil.h>
  31. #ifdef AVMB1_COMPAT
  32. #include <linux/b1lli.h>
  33. #endif
  34. #include <linux/mutex.h>
  35. static int showcapimsgs = 0;
  36. MODULE_DESCRIPTION("CAPI4Linux: kernel CAPI layer");
  37. MODULE_AUTHOR("Carsten Paeth");
  38. MODULE_LICENSE("GPL");
  39. module_param(showcapimsgs, uint, 0);
  40. /* ------------------------------------------------------------- */
  41. struct capictr_event {
  42. struct work_struct work;
  43. unsigned int type;
  44. u32 controller;
  45. };
  46. /* ------------------------------------------------------------- */
  47. static struct capi_version driver_version = {2, 0, 1, 1<<4};
  48. static char driver_serial[CAPI_SERIAL_LEN] = "0004711";
  49. static char capi_manufakturer[64] = "AVM Berlin";
  50. #define NCCI2CTRL(ncci) (((ncci) >> 24) & 0x7f)
  51. LIST_HEAD(capi_drivers);
  52. DEFINE_MUTEX(capi_drivers_lock);
  53. struct capi_ctr *capi_controller[CAPI_MAXCONTR];
  54. DEFINE_MUTEX(capi_controller_lock);
  55. static DEFINE_RWLOCK(application_lock);
  56. struct capi20_appl *capi_applications[CAPI_MAXAPPL];
  57. static int ncontrollers;
  58. static BLOCKING_NOTIFIER_HEAD(ctr_notifier_list);
  59. /* -------- controller ref counting -------------------------------------- */
  60. static inline struct capi_ctr *
  61. capi_ctr_get(struct capi_ctr *ctr)
  62. {
  63. if (!try_module_get(ctr->owner))
  64. return NULL;
  65. return ctr;
  66. }
  67. static inline void
  68. capi_ctr_put(struct capi_ctr *ctr)
  69. {
  70. module_put(ctr->owner);
  71. }
  72. /* ------------------------------------------------------------- */
  73. static inline struct capi_ctr *get_capi_ctr_by_nr(u16 contr)
  74. {
  75. if (contr - 1 >= CAPI_MAXCONTR)
  76. return NULL;
  77. return capi_controller[contr - 1];
  78. }
  79. static inline struct capi20_appl *get_capi_appl_by_nr(u16 applid)
  80. {
  81. if (applid - 1 >= CAPI_MAXAPPL)
  82. return NULL;
  83. return capi_applications[applid - 1];
  84. }
  85. /* -------- util functions ------------------------------------ */
  86. static inline int capi_cmd_valid(u8 cmd)
  87. {
  88. switch (cmd) {
  89. case CAPI_ALERT:
  90. case CAPI_CONNECT:
  91. case CAPI_CONNECT_ACTIVE:
  92. case CAPI_CONNECT_B3_ACTIVE:
  93. case CAPI_CONNECT_B3:
  94. case CAPI_CONNECT_B3_T90_ACTIVE:
  95. case CAPI_DATA_B3:
  96. case CAPI_DISCONNECT_B3:
  97. case CAPI_DISCONNECT:
  98. case CAPI_FACILITY:
  99. case CAPI_INFO:
  100. case CAPI_LISTEN:
  101. case CAPI_MANUFACTURER:
  102. case CAPI_RESET_B3:
  103. case CAPI_SELECT_B_PROTOCOL:
  104. return 1;
  105. }
  106. return 0;
  107. }
  108. static inline int capi_subcmd_valid(u8 subcmd)
  109. {
  110. switch (subcmd) {
  111. case CAPI_REQ:
  112. case CAPI_CONF:
  113. case CAPI_IND:
  114. case CAPI_RESP:
  115. return 1;
  116. }
  117. return 0;
  118. }
  119. /* ------------------------------------------------------------ */
  120. static void
  121. register_appl(struct capi_ctr *ctr, u16 applid, capi_register_params *rparam)
  122. {
  123. ctr = capi_ctr_get(ctr);
  124. if (ctr)
  125. ctr->register_appl(ctr, applid, rparam);
  126. else
  127. printk(KERN_WARNING "%s: cannot get controller resources\n",
  128. __func__);
  129. }
  130. static void release_appl(struct capi_ctr *ctr, u16 applid)
  131. {
  132. DBG("applid %#x", applid);
  133. ctr->release_appl(ctr, applid);
  134. capi_ctr_put(ctr);
  135. }
  136. static void notify_up(u32 contr)
  137. {
  138. struct capi20_appl *ap;
  139. struct capi_ctr *ctr;
  140. u16 applid;
  141. mutex_lock(&capi_controller_lock);
  142. if (showcapimsgs & 1)
  143. printk(KERN_DEBUG "kcapi: notify up contr %d\n", contr);
  144. ctr = get_capi_ctr_by_nr(contr);
  145. if (ctr) {
  146. if (ctr->state == CAPI_CTR_RUNNING)
  147. goto unlock_out;
  148. ctr->state = CAPI_CTR_RUNNING;
  149. for (applid = 1; applid <= CAPI_MAXAPPL; applid++) {
  150. ap = get_capi_appl_by_nr(applid);
  151. if (!ap || ap->release_in_progress)
  152. continue;
  153. register_appl(ctr, applid, &ap->rparam);
  154. }
  155. wake_up_interruptible_all(&ctr->state_wait_queue);
  156. } else
  157. printk(KERN_WARNING "%s: invalid contr %d\n", __func__, contr);
  158. unlock_out:
  159. mutex_unlock(&capi_controller_lock);
  160. }
  161. static void ctr_down(struct capi_ctr *ctr, int new_state)
  162. {
  163. struct capi20_appl *ap;
  164. u16 applid;
  165. if (ctr->state == CAPI_CTR_DETECTED || ctr->state == CAPI_CTR_DETACHED)
  166. return;
  167. ctr->state = new_state;
  168. memset(ctr->manu, 0, sizeof(ctr->manu));
  169. memset(&ctr->version, 0, sizeof(ctr->version));
  170. memset(&ctr->profile, 0, sizeof(ctr->profile));
  171. memset(ctr->serial, 0, sizeof(ctr->serial));
  172. for (applid = 1; applid <= CAPI_MAXAPPL; applid++) {
  173. ap = get_capi_appl_by_nr(applid);
  174. if (ap && !ap->release_in_progress)
  175. capi_ctr_put(ctr);
  176. }
  177. wake_up_interruptible_all(&ctr->state_wait_queue);
  178. }
  179. static void notify_down(u32 contr)
  180. {
  181. struct capi_ctr *ctr;
  182. mutex_lock(&capi_controller_lock);
  183. if (showcapimsgs & 1)
  184. printk(KERN_DEBUG "kcapi: notify down contr %d\n", contr);
  185. ctr = get_capi_ctr_by_nr(contr);
  186. if (ctr)
  187. ctr_down(ctr, CAPI_CTR_DETECTED);
  188. else
  189. printk(KERN_WARNING "%s: invalid contr %d\n", __func__, contr);
  190. mutex_unlock(&capi_controller_lock);
  191. }
  192. static int
  193. notify_handler(struct notifier_block *nb, unsigned long val, void *v)
  194. {
  195. u32 contr = (long)v;
  196. switch (val) {
  197. case CAPICTR_UP:
  198. notify_up(contr);
  199. break;
  200. case CAPICTR_DOWN:
  201. notify_down(contr);
  202. break;
  203. }
  204. return NOTIFY_OK;
  205. }
  206. static void do_notify_work(struct work_struct *work)
  207. {
  208. struct capictr_event *event =
  209. container_of(work, struct capictr_event, work);
  210. blocking_notifier_call_chain(&ctr_notifier_list, event->type,
  211. (void *)(long)event->controller);
  212. kfree(event);
  213. }
  214. /*
  215. * The notifier will result in adding/deleteing of devices. Devices can
  216. * only removed in user process, not in bh.
  217. */
  218. static int notify_push(unsigned int event_type, u32 controller)
  219. {
  220. struct capictr_event *event = kmalloc(sizeof(*event), GFP_ATOMIC);
  221. if (!event)
  222. return -ENOMEM;
  223. INIT_WORK(&event->work, do_notify_work);
  224. event->type = event_type;
  225. event->controller = controller;
  226. schedule_work(&event->work);
  227. return 0;
  228. }
  229. int register_capictr_notifier(struct notifier_block *nb)
  230. {
  231. return blocking_notifier_chain_register(&ctr_notifier_list, nb);
  232. }
  233. EXPORT_SYMBOL_GPL(register_capictr_notifier);
  234. int unregister_capictr_notifier(struct notifier_block *nb)
  235. {
  236. return blocking_notifier_chain_unregister(&ctr_notifier_list, nb);
  237. }
  238. EXPORT_SYMBOL_GPL(unregister_capictr_notifier);
  239. /* -------- Receiver ------------------------------------------ */
  240. static void recv_handler(struct work_struct *work)
  241. {
  242. struct sk_buff *skb;
  243. struct capi20_appl *ap =
  244. container_of(work, struct capi20_appl, recv_work);
  245. if ((!ap) || (ap->release_in_progress))
  246. return;
  247. mutex_lock(&ap->recv_mtx);
  248. while ((skb = skb_dequeue(&ap->recv_queue))) {
  249. if (CAPIMSG_CMD(skb->data) == CAPI_DATA_B3_IND)
  250. ap->nrecvdatapkt++;
  251. else
  252. ap->nrecvctlpkt++;
  253. ap->recv_message(ap, skb);
  254. }
  255. mutex_unlock(&ap->recv_mtx);
  256. }
  257. /**
  258. * capi_ctr_handle_message() - handle incoming CAPI message
  259. * @ctr: controller descriptor structure.
  260. * @appl: application ID.
  261. * @skb: message.
  262. *
  263. * Called by hardware driver to pass a CAPI message to the application.
  264. */
  265. void capi_ctr_handle_message(struct capi_ctr *ctr, u16 appl,
  266. struct sk_buff *skb)
  267. {
  268. struct capi20_appl *ap;
  269. int showctl = 0;
  270. u8 cmd, subcmd;
  271. unsigned long flags;
  272. _cdebbuf *cdb;
  273. if (ctr->state != CAPI_CTR_RUNNING) {
  274. cdb = capi_message2str(skb->data);
  275. if (cdb) {
  276. printk(KERN_INFO "kcapi: controller [%03d] not active, got: %s",
  277. ctr->cnr, cdb->buf);
  278. cdebbuf_free(cdb);
  279. } else
  280. printk(KERN_INFO "kcapi: controller [%03d] not active, cannot trace\n",
  281. ctr->cnr);
  282. goto error;
  283. }
  284. cmd = CAPIMSG_COMMAND(skb->data);
  285. subcmd = CAPIMSG_SUBCOMMAND(skb->data);
  286. if (cmd == CAPI_DATA_B3 && subcmd == CAPI_IND) {
  287. ctr->nrecvdatapkt++;
  288. if (ctr->traceflag > 2)
  289. showctl |= 2;
  290. } else {
  291. ctr->nrecvctlpkt++;
  292. if (ctr->traceflag)
  293. showctl |= 2;
  294. }
  295. showctl |= (ctr->traceflag & 1);
  296. if (showctl & 2) {
  297. if (showctl & 1) {
  298. printk(KERN_DEBUG "kcapi: got [%03d] id#%d %s len=%u\n",
  299. ctr->cnr, CAPIMSG_APPID(skb->data),
  300. capi_cmd2str(cmd, subcmd),
  301. CAPIMSG_LEN(skb->data));
  302. } else {
  303. cdb = capi_message2str(skb->data);
  304. if (cdb) {
  305. printk(KERN_DEBUG "kcapi: got [%03d] %s\n",
  306. ctr->cnr, cdb->buf);
  307. cdebbuf_free(cdb);
  308. } else
  309. printk(KERN_DEBUG "kcapi: got [%03d] id#%d %s len=%u, cannot trace\n",
  310. ctr->cnr, CAPIMSG_APPID(skb->data),
  311. capi_cmd2str(cmd, subcmd),
  312. CAPIMSG_LEN(skb->data));
  313. }
  314. }
  315. read_lock_irqsave(&application_lock, flags);
  316. ap = get_capi_appl_by_nr(CAPIMSG_APPID(skb->data));
  317. if ((!ap) || (ap->release_in_progress)) {
  318. read_unlock_irqrestore(&application_lock, flags);
  319. cdb = capi_message2str(skb->data);
  320. if (cdb) {
  321. printk(KERN_ERR "kcapi: handle_message: applid %d state released (%s)\n",
  322. CAPIMSG_APPID(skb->data), cdb->buf);
  323. cdebbuf_free(cdb);
  324. } else
  325. printk(KERN_ERR "kcapi: handle_message: applid %d state released (%s) cannot trace\n",
  326. CAPIMSG_APPID(skb->data),
  327. capi_cmd2str(cmd, subcmd));
  328. goto error;
  329. }
  330. skb_queue_tail(&ap->recv_queue, skb);
  331. schedule_work(&ap->recv_work);
  332. read_unlock_irqrestore(&application_lock, flags);
  333. return;
  334. error:
  335. kfree_skb(skb);
  336. }
  337. EXPORT_SYMBOL(capi_ctr_handle_message);
  338. /**
  339. * capi_ctr_ready() - signal CAPI controller ready
  340. * @ctr: controller descriptor structure.
  341. *
  342. * Called by hardware driver to signal that the controller is up and running.
  343. */
  344. void capi_ctr_ready(struct capi_ctr *ctr)
  345. {
  346. printk(KERN_NOTICE "kcapi: controller [%03d] \"%s\" ready.\n",
  347. ctr->cnr, ctr->name);
  348. notify_push(CAPICTR_UP, ctr->cnr);
  349. }
  350. EXPORT_SYMBOL(capi_ctr_ready);
  351. /**
  352. * capi_ctr_down() - signal CAPI controller not ready
  353. * @ctr: controller descriptor structure.
  354. *
  355. * Called by hardware driver to signal that the controller is down and
  356. * unavailable for use.
  357. */
  358. void capi_ctr_down(struct capi_ctr *ctr)
  359. {
  360. printk(KERN_NOTICE "kcapi: controller [%03d] down.\n", ctr->cnr);
  361. notify_push(CAPICTR_DOWN, ctr->cnr);
  362. }
  363. EXPORT_SYMBOL(capi_ctr_down);
  364. /**
  365. * capi_ctr_suspend_output() - suspend controller
  366. * @ctr: controller descriptor structure.
  367. *
  368. * Called by hardware driver to stop data flow.
  369. *
  370. * Note: The caller is responsible for synchronizing concurrent state changes
  371. * as well as invocations of capi_ctr_handle_message.
  372. */
  373. void capi_ctr_suspend_output(struct capi_ctr *ctr)
  374. {
  375. if (!ctr->blocked) {
  376. printk(KERN_DEBUG "kcapi: controller [%03d] suspend\n",
  377. ctr->cnr);
  378. ctr->blocked = 1;
  379. }
  380. }
  381. EXPORT_SYMBOL(capi_ctr_suspend_output);
  382. /**
  383. * capi_ctr_resume_output() - resume controller
  384. * @ctr: controller descriptor structure.
  385. *
  386. * Called by hardware driver to resume data flow.
  387. *
  388. * Note: The caller is responsible for synchronizing concurrent state changes
  389. * as well as invocations of capi_ctr_handle_message.
  390. */
  391. void capi_ctr_resume_output(struct capi_ctr *ctr)
  392. {
  393. if (ctr->blocked) {
  394. printk(KERN_DEBUG "kcapi: controller [%03d] resumed\n",
  395. ctr->cnr);
  396. ctr->blocked = 0;
  397. }
  398. }
  399. EXPORT_SYMBOL(capi_ctr_resume_output);
  400. /* ------------------------------------------------------------- */
  401. /**
  402. * attach_capi_ctr() - register CAPI controller
  403. * @ctr: controller descriptor structure.
  404. *
  405. * Called by hardware driver to register a controller with the CAPI subsystem.
  406. * Return value: 0 on success, error code < 0 on error
  407. */
  408. int attach_capi_ctr(struct capi_ctr *ctr)
  409. {
  410. int i;
  411. mutex_lock(&capi_controller_lock);
  412. for (i = 0; i < CAPI_MAXCONTR; i++) {
  413. if (!capi_controller[i])
  414. break;
  415. }
  416. if (i == CAPI_MAXCONTR) {
  417. mutex_unlock(&capi_controller_lock);
  418. printk(KERN_ERR "kcapi: out of controller slots\n");
  419. return -EBUSY;
  420. }
  421. capi_controller[i] = ctr;
  422. ctr->nrecvctlpkt = 0;
  423. ctr->nrecvdatapkt = 0;
  424. ctr->nsentctlpkt = 0;
  425. ctr->nsentdatapkt = 0;
  426. ctr->cnr = i + 1;
  427. ctr->state = CAPI_CTR_DETECTED;
  428. ctr->blocked = 0;
  429. ctr->traceflag = showcapimsgs;
  430. init_waitqueue_head(&ctr->state_wait_queue);
  431. sprintf(ctr->procfn, "capi/controllers/%d", ctr->cnr);
  432. ctr->procent = proc_create_data(ctr->procfn, 0, NULL, ctr->proc_fops, ctr);
  433. ncontrollers++;
  434. mutex_unlock(&capi_controller_lock);
  435. printk(KERN_NOTICE "kcapi: controller [%03d]: %s attached\n",
  436. ctr->cnr, ctr->name);
  437. return 0;
  438. }
  439. EXPORT_SYMBOL(attach_capi_ctr);
  440. /**
  441. * detach_capi_ctr() - unregister CAPI controller
  442. * @ctr: controller descriptor structure.
  443. *
  444. * Called by hardware driver to remove the registration of a controller
  445. * with the CAPI subsystem.
  446. * Return value: 0 on success, error code < 0 on error
  447. */
  448. int detach_capi_ctr(struct capi_ctr *ctr)
  449. {
  450. int err = 0;
  451. mutex_lock(&capi_controller_lock);
  452. ctr_down(ctr, CAPI_CTR_DETACHED);
  453. if (capi_controller[ctr->cnr - 1] != ctr) {
  454. err = -EINVAL;
  455. goto unlock_out;
  456. }
  457. capi_controller[ctr->cnr - 1] = NULL;
  458. ncontrollers--;
  459. if (ctr->procent)
  460. remove_proc_entry(ctr->procfn, NULL);
  461. printk(KERN_NOTICE "kcapi: controller [%03d]: %s unregistered\n",
  462. ctr->cnr, ctr->name);
  463. unlock_out:
  464. mutex_unlock(&capi_controller_lock);
  465. return err;
  466. }
  467. EXPORT_SYMBOL(detach_capi_ctr);
  468. /**
  469. * register_capi_driver() - register CAPI driver
  470. * @driver: driver descriptor structure.
  471. *
  472. * Called by hardware driver to register itself with the CAPI subsystem.
  473. */
  474. void register_capi_driver(struct capi_driver *driver)
  475. {
  476. mutex_lock(&capi_drivers_lock);
  477. list_add_tail(&driver->list, &capi_drivers);
  478. mutex_unlock(&capi_drivers_lock);
  479. }
  480. EXPORT_SYMBOL(register_capi_driver);
  481. /**
  482. * unregister_capi_driver() - unregister CAPI driver
  483. * @driver: driver descriptor structure.
  484. *
  485. * Called by hardware driver to unregister itself from the CAPI subsystem.
  486. */
  487. void unregister_capi_driver(struct capi_driver *driver)
  488. {
  489. mutex_lock(&capi_drivers_lock);
  490. list_del(&driver->list);
  491. mutex_unlock(&capi_drivers_lock);
  492. }
  493. EXPORT_SYMBOL(unregister_capi_driver);
  494. /* ------------------------------------------------------------- */
  495. /* -------- CAPI2.0 Interface ---------------------------------- */
  496. /* ------------------------------------------------------------- */
  497. /**
  498. * capi20_isinstalled() - CAPI 2.0 operation CAPI_INSTALLED
  499. *
  500. * Return value: CAPI result code (CAPI_NOERROR if at least one ISDN controller
  501. * is ready for use, CAPI_REGNOTINSTALLED otherwise)
  502. */
  503. u16 capi20_isinstalled(void)
  504. {
  505. u16 ret = CAPI_REGNOTINSTALLED;
  506. int i;
  507. mutex_lock(&capi_controller_lock);
  508. for (i = 0; i < CAPI_MAXCONTR; i++)
  509. if (capi_controller[i] &&
  510. capi_controller[i]->state == CAPI_CTR_RUNNING) {
  511. ret = CAPI_NOERROR;
  512. break;
  513. }
  514. mutex_unlock(&capi_controller_lock);
  515. return ret;
  516. }
  517. EXPORT_SYMBOL(capi20_isinstalled);
  518. /**
  519. * capi20_register() - CAPI 2.0 operation CAPI_REGISTER
  520. * @ap: CAPI application descriptor structure.
  521. *
  522. * Register an application's presence with CAPI.
  523. * A unique application ID is assigned and stored in @ap->applid.
  524. * After this function returns successfully, the message receive
  525. * callback function @ap->recv_message() may be called at any time
  526. * until capi20_release() has been called for the same @ap.
  527. * Return value: CAPI result code
  528. */
  529. u16 capi20_register(struct capi20_appl *ap)
  530. {
  531. int i;
  532. u16 applid;
  533. unsigned long flags;
  534. DBG("");
  535. if (ap->rparam.datablklen < 128)
  536. return CAPI_LOGBLKSIZETOSMALL;
  537. write_lock_irqsave(&application_lock, flags);
  538. for (applid = 1; applid <= CAPI_MAXAPPL; applid++) {
  539. if (capi_applications[applid - 1] == NULL)
  540. break;
  541. }
  542. if (applid > CAPI_MAXAPPL) {
  543. write_unlock_irqrestore(&application_lock, flags);
  544. return CAPI_TOOMANYAPPLS;
  545. }
  546. ap->applid = applid;
  547. capi_applications[applid - 1] = ap;
  548. ap->nrecvctlpkt = 0;
  549. ap->nrecvdatapkt = 0;
  550. ap->nsentctlpkt = 0;
  551. ap->nsentdatapkt = 0;
  552. mutex_init(&ap->recv_mtx);
  553. skb_queue_head_init(&ap->recv_queue);
  554. INIT_WORK(&ap->recv_work, recv_handler);
  555. ap->release_in_progress = 0;
  556. write_unlock_irqrestore(&application_lock, flags);
  557. mutex_lock(&capi_controller_lock);
  558. for (i = 0; i < CAPI_MAXCONTR; i++) {
  559. if (!capi_controller[i] ||
  560. capi_controller[i]->state != CAPI_CTR_RUNNING)
  561. continue;
  562. register_appl(capi_controller[i], applid, &ap->rparam);
  563. }
  564. mutex_unlock(&capi_controller_lock);
  565. if (showcapimsgs & 1) {
  566. printk(KERN_DEBUG "kcapi: appl %d up\n", applid);
  567. }
  568. return CAPI_NOERROR;
  569. }
  570. EXPORT_SYMBOL(capi20_register);
  571. /**
  572. * capi20_release() - CAPI 2.0 operation CAPI_RELEASE
  573. * @ap: CAPI application descriptor structure.
  574. *
  575. * Terminate an application's registration with CAPI.
  576. * After this function returns successfully, the message receive
  577. * callback function @ap->recv_message() will no longer be called.
  578. * Return value: CAPI result code
  579. */
  580. u16 capi20_release(struct capi20_appl *ap)
  581. {
  582. int i;
  583. unsigned long flags;
  584. DBG("applid %#x", ap->applid);
  585. write_lock_irqsave(&application_lock, flags);
  586. ap->release_in_progress = 1;
  587. capi_applications[ap->applid - 1] = NULL;
  588. write_unlock_irqrestore(&application_lock, flags);
  589. mutex_lock(&capi_controller_lock);
  590. for (i = 0; i < CAPI_MAXCONTR; i++) {
  591. if (!capi_controller[i] ||
  592. capi_controller[i]->state != CAPI_CTR_RUNNING)
  593. continue;
  594. release_appl(capi_controller[i], ap->applid);
  595. }
  596. mutex_unlock(&capi_controller_lock);
  597. flush_scheduled_work();
  598. skb_queue_purge(&ap->recv_queue);
  599. if (showcapimsgs & 1) {
  600. printk(KERN_DEBUG "kcapi: appl %d down\n", ap->applid);
  601. }
  602. return CAPI_NOERROR;
  603. }
  604. EXPORT_SYMBOL(capi20_release);
  605. /**
  606. * capi20_put_message() - CAPI 2.0 operation CAPI_PUT_MESSAGE
  607. * @ap: CAPI application descriptor structure.
  608. * @skb: CAPI message.
  609. *
  610. * Transfer a single message to CAPI.
  611. * Return value: CAPI result code
  612. */
  613. u16 capi20_put_message(struct capi20_appl *ap, struct sk_buff *skb)
  614. {
  615. struct capi_ctr *ctr;
  616. int showctl = 0;
  617. u8 cmd, subcmd;
  618. DBG("applid %#x", ap->applid);
  619. if (ncontrollers == 0)
  620. return CAPI_REGNOTINSTALLED;
  621. if ((ap->applid == 0) || ap->release_in_progress)
  622. return CAPI_ILLAPPNR;
  623. if (skb->len < 12
  624. || !capi_cmd_valid(CAPIMSG_COMMAND(skb->data))
  625. || !capi_subcmd_valid(CAPIMSG_SUBCOMMAND(skb->data)))
  626. return CAPI_ILLCMDORSUBCMDORMSGTOSMALL;
  627. /*
  628. * The controller reference is protected by the existence of the
  629. * application passed to us. We assume that the caller properly
  630. * synchronizes this service with capi20_release.
  631. */
  632. ctr = get_capi_ctr_by_nr(CAPIMSG_CONTROLLER(skb->data));
  633. if (!ctr || ctr->state != CAPI_CTR_RUNNING) {
  634. ctr = get_capi_ctr_by_nr(1); /* XXX why? */
  635. if (!ctr || ctr->state != CAPI_CTR_RUNNING)
  636. return CAPI_REGNOTINSTALLED;
  637. }
  638. if (ctr->blocked)
  639. return CAPI_SENDQUEUEFULL;
  640. cmd = CAPIMSG_COMMAND(skb->data);
  641. subcmd = CAPIMSG_SUBCOMMAND(skb->data);
  642. if (cmd == CAPI_DATA_B3 && subcmd== CAPI_REQ) {
  643. ctr->nsentdatapkt++;
  644. ap->nsentdatapkt++;
  645. if (ctr->traceflag > 2)
  646. showctl |= 2;
  647. } else {
  648. ctr->nsentctlpkt++;
  649. ap->nsentctlpkt++;
  650. if (ctr->traceflag)
  651. showctl |= 2;
  652. }
  653. showctl |= (ctr->traceflag & 1);
  654. if (showctl & 2) {
  655. if (showctl & 1) {
  656. printk(KERN_DEBUG "kcapi: put [%03d] id#%d %s len=%u\n",
  657. CAPIMSG_CONTROLLER(skb->data),
  658. CAPIMSG_APPID(skb->data),
  659. capi_cmd2str(cmd, subcmd),
  660. CAPIMSG_LEN(skb->data));
  661. } else {
  662. _cdebbuf *cdb = capi_message2str(skb->data);
  663. if (cdb) {
  664. printk(KERN_DEBUG "kcapi: put [%03d] %s\n",
  665. CAPIMSG_CONTROLLER(skb->data),
  666. cdb->buf);
  667. cdebbuf_free(cdb);
  668. } else
  669. printk(KERN_DEBUG "kcapi: put [%03d] id#%d %s len=%u cannot trace\n",
  670. CAPIMSG_CONTROLLER(skb->data),
  671. CAPIMSG_APPID(skb->data),
  672. capi_cmd2str(cmd, subcmd),
  673. CAPIMSG_LEN(skb->data));
  674. }
  675. }
  676. return ctr->send_message(ctr, skb);
  677. }
  678. EXPORT_SYMBOL(capi20_put_message);
  679. /**
  680. * capi20_get_manufacturer() - CAPI 2.0 operation CAPI_GET_MANUFACTURER
  681. * @contr: controller number.
  682. * @buf: result buffer (64 bytes).
  683. *
  684. * Retrieve information about the manufacturer of the specified ISDN controller
  685. * or (for @contr == 0) the driver itself.
  686. * Return value: CAPI result code
  687. */
  688. u16 capi20_get_manufacturer(u32 contr, u8 *buf)
  689. {
  690. struct capi_ctr *ctr;
  691. u16 ret;
  692. if (contr == 0) {
  693. strlcpy(buf, capi_manufakturer, CAPI_MANUFACTURER_LEN);
  694. return CAPI_NOERROR;
  695. }
  696. mutex_lock(&capi_controller_lock);
  697. ctr = get_capi_ctr_by_nr(contr);
  698. if (ctr && ctr->state == CAPI_CTR_RUNNING) {
  699. strlcpy(buf, ctr->manu, CAPI_MANUFACTURER_LEN);
  700. ret = CAPI_NOERROR;
  701. } else
  702. ret = CAPI_REGNOTINSTALLED;
  703. mutex_unlock(&capi_controller_lock);
  704. return ret;
  705. }
  706. EXPORT_SYMBOL(capi20_get_manufacturer);
  707. /**
  708. * capi20_get_version() - CAPI 2.0 operation CAPI_GET_VERSION
  709. * @contr: controller number.
  710. * @verp: result structure.
  711. *
  712. * Retrieve version information for the specified ISDN controller
  713. * or (for @contr == 0) the driver itself.
  714. * Return value: CAPI result code
  715. */
  716. u16 capi20_get_version(u32 contr, struct capi_version *verp)
  717. {
  718. struct capi_ctr *ctr;
  719. u16 ret;
  720. if (contr == 0) {
  721. *verp = driver_version;
  722. return CAPI_NOERROR;
  723. }
  724. mutex_lock(&capi_controller_lock);
  725. ctr = get_capi_ctr_by_nr(contr);
  726. if (ctr && ctr->state == CAPI_CTR_RUNNING) {
  727. memcpy(verp, &ctr->version, sizeof(capi_version));
  728. ret = CAPI_NOERROR;
  729. } else
  730. ret = CAPI_REGNOTINSTALLED;
  731. mutex_unlock(&capi_controller_lock);
  732. return ret;
  733. }
  734. EXPORT_SYMBOL(capi20_get_version);
  735. /**
  736. * capi20_get_serial() - CAPI 2.0 operation CAPI_GET_SERIAL_NUMBER
  737. * @contr: controller number.
  738. * @serial: result buffer (8 bytes).
  739. *
  740. * Retrieve the serial number of the specified ISDN controller
  741. * or (for @contr == 0) the driver itself.
  742. * Return value: CAPI result code
  743. */
  744. u16 capi20_get_serial(u32 contr, u8 *serial)
  745. {
  746. struct capi_ctr *ctr;
  747. u16 ret;
  748. if (contr == 0) {
  749. strlcpy(serial, driver_serial, CAPI_SERIAL_LEN);
  750. return CAPI_NOERROR;
  751. }
  752. mutex_lock(&capi_controller_lock);
  753. ctr = get_capi_ctr_by_nr(contr);
  754. if (ctr && ctr->state == CAPI_CTR_RUNNING) {
  755. strlcpy(serial, ctr->serial, CAPI_SERIAL_LEN);
  756. ret = CAPI_NOERROR;
  757. } else
  758. ret = CAPI_REGNOTINSTALLED;
  759. mutex_unlock(&capi_controller_lock);
  760. return ret;
  761. }
  762. EXPORT_SYMBOL(capi20_get_serial);
  763. /**
  764. * capi20_get_profile() - CAPI 2.0 operation CAPI_GET_PROFILE
  765. * @contr: controller number.
  766. * @profp: result structure.
  767. *
  768. * Retrieve capability information for the specified ISDN controller
  769. * or (for @contr == 0) the number of installed controllers.
  770. * Return value: CAPI result code
  771. */
  772. u16 capi20_get_profile(u32 contr, struct capi_profile *profp)
  773. {
  774. struct capi_ctr *ctr;
  775. u16 ret;
  776. if (contr == 0) {
  777. profp->ncontroller = ncontrollers;
  778. return CAPI_NOERROR;
  779. }
  780. mutex_lock(&capi_controller_lock);
  781. ctr = get_capi_ctr_by_nr(contr);
  782. if (ctr && ctr->state == CAPI_CTR_RUNNING) {
  783. memcpy(profp, &ctr->profile, sizeof(struct capi_profile));
  784. ret = CAPI_NOERROR;
  785. } else
  786. ret = CAPI_REGNOTINSTALLED;
  787. mutex_unlock(&capi_controller_lock);
  788. return ret;
  789. }
  790. EXPORT_SYMBOL(capi20_get_profile);
  791. /* Must be called with capi_controller_lock held. */
  792. static int wait_on_ctr_state(struct capi_ctr *ctr, unsigned int state)
  793. {
  794. DEFINE_WAIT(wait);
  795. int retval = 0;
  796. ctr = capi_ctr_get(ctr);
  797. if (!ctr)
  798. return -ESRCH;
  799. for (;;) {
  800. prepare_to_wait(&ctr->state_wait_queue, &wait,
  801. TASK_INTERRUPTIBLE);
  802. if (ctr->state == state)
  803. break;
  804. if (ctr->state == CAPI_CTR_DETACHED) {
  805. retval = -ESRCH;
  806. break;
  807. }
  808. if (signal_pending(current)) {
  809. retval = -EINTR;
  810. break;
  811. }
  812. mutex_unlock(&capi_controller_lock);
  813. schedule();
  814. mutex_lock(&capi_controller_lock);
  815. }
  816. finish_wait(&ctr->state_wait_queue, &wait);
  817. capi_ctr_put(ctr);
  818. return retval;
  819. }
  820. #ifdef AVMB1_COMPAT
  821. static int old_capi_manufacturer(unsigned int cmd, void __user *data)
  822. {
  823. avmb1_loadandconfigdef ldef;
  824. avmb1_extcarddef cdef;
  825. avmb1_resetdef rdef;
  826. capicardparams cparams;
  827. struct capi_ctr *ctr;
  828. struct capi_driver *driver = NULL;
  829. capiloaddata ldata;
  830. struct list_head *l;
  831. int retval;
  832. switch (cmd) {
  833. case AVMB1_ADDCARD:
  834. case AVMB1_ADDCARD_WITH_TYPE:
  835. if (cmd == AVMB1_ADDCARD) {
  836. if ((retval = copy_from_user(&cdef, data,
  837. sizeof(avmb1_carddef))))
  838. return retval;
  839. cdef.cardtype = AVM_CARDTYPE_B1;
  840. } else {
  841. if ((retval = copy_from_user(&cdef, data,
  842. sizeof(avmb1_extcarddef))))
  843. return retval;
  844. }
  845. cparams.port = cdef.port;
  846. cparams.irq = cdef.irq;
  847. cparams.cardnr = cdef.cardnr;
  848. mutex_lock(&capi_drivers_lock);
  849. switch (cdef.cardtype) {
  850. case AVM_CARDTYPE_B1:
  851. list_for_each(l, &capi_drivers) {
  852. driver = list_entry(l, struct capi_driver, list);
  853. if (strcmp(driver->name, "b1isa") == 0)
  854. break;
  855. }
  856. break;
  857. case AVM_CARDTYPE_T1:
  858. list_for_each(l, &capi_drivers) {
  859. driver = list_entry(l, struct capi_driver, list);
  860. if (strcmp(driver->name, "t1isa") == 0)
  861. break;
  862. }
  863. break;
  864. default:
  865. driver = NULL;
  866. break;
  867. }
  868. if (!driver) {
  869. printk(KERN_ERR "kcapi: driver not loaded.\n");
  870. retval = -EIO;
  871. } else if (!driver->add_card) {
  872. printk(KERN_ERR "kcapi: driver has no add card function.\n");
  873. retval = -EIO;
  874. } else
  875. retval = driver->add_card(driver, &cparams);
  876. mutex_unlock(&capi_drivers_lock);
  877. return retval;
  878. case AVMB1_LOAD:
  879. case AVMB1_LOAD_AND_CONFIG:
  880. if (cmd == AVMB1_LOAD) {
  881. if (copy_from_user(&ldef, data,
  882. sizeof(avmb1_loaddef)))
  883. return -EFAULT;
  884. ldef.t4config.len = 0;
  885. ldef.t4config.data = NULL;
  886. } else {
  887. if (copy_from_user(&ldef, data,
  888. sizeof(avmb1_loadandconfigdef)))
  889. return -EFAULT;
  890. }
  891. mutex_lock(&capi_controller_lock);
  892. ctr = get_capi_ctr_by_nr(ldef.contr);
  893. if (!ctr) {
  894. retval = -EINVAL;
  895. goto load_unlock_out;
  896. }
  897. if (ctr->load_firmware == NULL) {
  898. printk(KERN_DEBUG "kcapi: load: no load function\n");
  899. retval = -ESRCH;
  900. goto load_unlock_out;
  901. }
  902. if (ldef.t4file.len <= 0) {
  903. printk(KERN_DEBUG "kcapi: load: invalid parameter: length of t4file is %d ?\n", ldef.t4file.len);
  904. retval = -EINVAL;
  905. goto load_unlock_out;
  906. }
  907. if (ldef.t4file.data == NULL) {
  908. printk(KERN_DEBUG "kcapi: load: invalid parameter: dataptr is 0\n");
  909. retval = -EINVAL;
  910. goto load_unlock_out;
  911. }
  912. ldata.firmware.user = 1;
  913. ldata.firmware.data = ldef.t4file.data;
  914. ldata.firmware.len = ldef.t4file.len;
  915. ldata.configuration.user = 1;
  916. ldata.configuration.data = ldef.t4config.data;
  917. ldata.configuration.len = ldef.t4config.len;
  918. if (ctr->state != CAPI_CTR_DETECTED) {
  919. printk(KERN_INFO "kcapi: load: contr=%d not in detect state\n", ldef.contr);
  920. retval = -EBUSY;
  921. goto load_unlock_out;
  922. }
  923. ctr->state = CAPI_CTR_LOADING;
  924. retval = ctr->load_firmware(ctr, &ldata);
  925. if (retval) {
  926. ctr->state = CAPI_CTR_DETECTED;
  927. goto load_unlock_out;
  928. }
  929. retval = wait_on_ctr_state(ctr, CAPI_CTR_RUNNING);
  930. load_unlock_out:
  931. mutex_unlock(&capi_controller_lock);
  932. return retval;
  933. case AVMB1_RESETCARD:
  934. if (copy_from_user(&rdef, data, sizeof(avmb1_resetdef)))
  935. return -EFAULT;
  936. retval = 0;
  937. mutex_lock(&capi_controller_lock);
  938. ctr = get_capi_ctr_by_nr(rdef.contr);
  939. if (!ctr) {
  940. retval = -ESRCH;
  941. goto reset_unlock_out;
  942. }
  943. if (ctr->state == CAPI_CTR_DETECTED)
  944. goto reset_unlock_out;
  945. ctr->reset_ctr(ctr);
  946. retval = wait_on_ctr_state(ctr, CAPI_CTR_DETECTED);
  947. reset_unlock_out:
  948. mutex_unlock(&capi_controller_lock);
  949. return retval;
  950. }
  951. return -EINVAL;
  952. }
  953. #endif
  954. /**
  955. * capi20_manufacturer() - CAPI 2.0 operation CAPI_MANUFACTURER
  956. * @cmd: command.
  957. * @data: parameter.
  958. *
  959. * Perform manufacturer specific command.
  960. * Return value: CAPI result code
  961. */
  962. int capi20_manufacturer(unsigned int cmd, void __user *data)
  963. {
  964. struct capi_ctr *ctr;
  965. int retval;
  966. switch (cmd) {
  967. #ifdef AVMB1_COMPAT
  968. case AVMB1_LOAD:
  969. case AVMB1_LOAD_AND_CONFIG:
  970. case AVMB1_RESETCARD:
  971. case AVMB1_GET_CARDINFO:
  972. case AVMB1_REMOVECARD:
  973. return old_capi_manufacturer(cmd, data);
  974. #endif
  975. case KCAPI_CMD_TRACE:
  976. {
  977. kcapi_flagdef fdef;
  978. if (copy_from_user(&fdef, data, sizeof(kcapi_flagdef)))
  979. return -EFAULT;
  980. mutex_lock(&capi_controller_lock);
  981. ctr = get_capi_ctr_by_nr(fdef.contr);
  982. if (ctr) {
  983. ctr->traceflag = fdef.flag;
  984. printk(KERN_INFO "kcapi: contr [%03d] set trace=%d\n",
  985. ctr->cnr, ctr->traceflag);
  986. retval = 0;
  987. } else
  988. retval = -ESRCH;
  989. mutex_unlock(&capi_controller_lock);
  990. return retval;
  991. }
  992. case KCAPI_CMD_ADDCARD:
  993. {
  994. struct list_head *l;
  995. struct capi_driver *driver = NULL;
  996. capicardparams cparams;
  997. kcapi_carddef cdef;
  998. if ((retval = copy_from_user(&cdef, data, sizeof(cdef))))
  999. return retval;
  1000. cparams.port = cdef.port;
  1001. cparams.irq = cdef.irq;
  1002. cparams.membase = cdef.membase;
  1003. cparams.cardnr = cdef.cardnr;
  1004. cparams.cardtype = 0;
  1005. cdef.driver[sizeof(cdef.driver)-1] = 0;
  1006. mutex_lock(&capi_drivers_lock);
  1007. list_for_each(l, &capi_drivers) {
  1008. driver = list_entry(l, struct capi_driver, list);
  1009. if (strcmp(driver->name, cdef.driver) == 0)
  1010. break;
  1011. }
  1012. if (driver == NULL) {
  1013. printk(KERN_ERR "kcapi: driver \"%s\" not loaded.\n",
  1014. cdef.driver);
  1015. retval = -ESRCH;
  1016. } else if (!driver->add_card) {
  1017. printk(KERN_ERR "kcapi: driver \"%s\" has no add card function.\n", cdef.driver);
  1018. retval = -EIO;
  1019. } else
  1020. retval = driver->add_card(driver, &cparams);
  1021. mutex_unlock(&capi_drivers_lock);
  1022. return retval;
  1023. }
  1024. default:
  1025. printk(KERN_ERR "kcapi: manufacturer command %d unknown.\n",
  1026. cmd);
  1027. break;
  1028. }
  1029. return -EINVAL;
  1030. }
  1031. EXPORT_SYMBOL(capi20_manufacturer);
  1032. /* ------------------------------------------------------------- */
  1033. /* -------- Init & Cleanup ------------------------------------- */
  1034. /* ------------------------------------------------------------- */
  1035. /*
  1036. * init / exit functions
  1037. */
  1038. static struct notifier_block capictr_nb = {
  1039. .notifier_call = notify_handler,
  1040. .priority = INT_MAX,
  1041. };
  1042. static int __init kcapi_init(void)
  1043. {
  1044. int err;
  1045. register_capictr_notifier(&capictr_nb);
  1046. err = cdebug_init();
  1047. if (!err)
  1048. kcapi_proc_init();
  1049. return err;
  1050. }
  1051. static void __exit kcapi_exit(void)
  1052. {
  1053. kcapi_proc_exit();
  1054. /* make sure all notifiers are finished */
  1055. flush_scheduled_work();
  1056. cdebug_exit();
  1057. }
  1058. module_init(kcapi_init);
  1059. module_exit(kcapi_exit);