diva_didd.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. /* $Id: diva_didd.c,v 1.13.6.4 2005/02/11 19:40:25 armin Exp $
  2. *
  3. * DIDD Interface module for Eicon active cards.
  4. *
  5. * Functions are in dadapter.c
  6. *
  7. * Copyright 2002-2003 by Armin Schindler (mac@melware.de)
  8. * Copyright 2002-2003 Cytronics & Melware (info@melware.de)
  9. *
  10. * This software may be used and distributed according to the terms
  11. * of the GNU General Public License, incorporated herein by reference.
  12. */
  13. #include <linux/module.h>
  14. #include <linux/init.h>
  15. #include <linux/kernel.h>
  16. #include <linux/proc_fs.h>
  17. #include <net/net_namespace.h>
  18. #include "platform.h"
  19. #include "di_defs.h"
  20. #include "dadapter.h"
  21. #include "divasync.h"
  22. #include "did_vers.h"
  23. static char *main_revision = "$Revision: 1.13.6.4 $";
  24. static char *DRIVERNAME =
  25. "Eicon DIVA - DIDD table (http://www.melware.net)";
  26. static char *DRIVERLNAME = "divadidd";
  27. char *DRIVERRELEASE_DIDD = "2.0";
  28. MODULE_DESCRIPTION("DIDD table driver for diva drivers");
  29. MODULE_AUTHOR("Cytronics & Melware, Eicon Networks");
  30. MODULE_SUPPORTED_DEVICE("Eicon diva drivers");
  31. MODULE_LICENSE("GPL");
  32. #define DBG_MINIMUM (DL_LOG + DL_FTL + DL_ERR)
  33. #define DBG_DEFAULT (DBG_MINIMUM + DL_XLOG + DL_REG)
  34. extern int diddfunc_init(void);
  35. extern void diddfunc_finit(void);
  36. extern void DIVA_DIDD_Read(void *, int);
  37. static struct proc_dir_entry *proc_didd;
  38. struct proc_dir_entry *proc_net_eicon = NULL;
  39. EXPORT_SYMBOL(DIVA_DIDD_Read);
  40. EXPORT_SYMBOL(proc_net_eicon);
  41. static char *getrev(const char *revision)
  42. {
  43. char *rev;
  44. char *p;
  45. if ((p = strchr(revision, ':'))) {
  46. rev = p + 2;
  47. p = strchr(rev, '$');
  48. *--p = 0;
  49. } else
  50. rev = "1.0";
  51. return rev;
  52. }
  53. static int
  54. proc_read(char *page, char **start, off_t off, int count, int *eof,
  55. void *data)
  56. {
  57. int len = 0;
  58. char tmprev[32];
  59. strcpy(tmprev, main_revision);
  60. len += sprintf(page + len, "%s\n", DRIVERNAME);
  61. len += sprintf(page + len, "name : %s\n", DRIVERLNAME);
  62. len += sprintf(page + len, "release : %s\n", DRIVERRELEASE_DIDD);
  63. len += sprintf(page + len, "build : %s(%s)\n",
  64. diva_didd_common_code_build, DIVA_BUILD);
  65. len += sprintf(page + len, "revision : %s\n", getrev(tmprev));
  66. if (off + count >= len)
  67. *eof = 1;
  68. if (len < off)
  69. return 0;
  70. *start = page + off;
  71. return ((count < len - off) ? count : len - off);
  72. }
  73. static int DIVA_INIT_FUNCTION create_proc(void)
  74. {
  75. proc_net_eicon = proc_mkdir("eicon", init_net.proc_net);
  76. if (proc_net_eicon) {
  77. if ((proc_didd =
  78. create_proc_entry(DRIVERLNAME, S_IFREG | S_IRUGO,
  79. proc_net_eicon))) {
  80. proc_didd->read_proc = proc_read;
  81. }
  82. return (1);
  83. }
  84. return (0);
  85. }
  86. static void remove_proc(void)
  87. {
  88. remove_proc_entry(DRIVERLNAME, proc_net_eicon);
  89. remove_proc_entry("eicon", init_net.proc_net);
  90. }
  91. static int DIVA_INIT_FUNCTION divadidd_init(void)
  92. {
  93. char tmprev[32];
  94. int ret = 0;
  95. printk(KERN_INFO "%s\n", DRIVERNAME);
  96. printk(KERN_INFO "%s: Rel:%s Rev:", DRIVERLNAME, DRIVERRELEASE_DIDD);
  97. strcpy(tmprev, main_revision);
  98. printk("%s Build:%s(%s)\n", getrev(tmprev),
  99. diva_didd_common_code_build, DIVA_BUILD);
  100. if (!create_proc()) {
  101. printk(KERN_ERR "%s: could not create proc entry\n",
  102. DRIVERLNAME);
  103. ret = -EIO;
  104. goto out;
  105. }
  106. if (!diddfunc_init()) {
  107. printk(KERN_ERR "%s: failed to connect to DIDD.\n",
  108. DRIVERLNAME);
  109. #ifdef MODULE
  110. remove_proc();
  111. #endif
  112. ret = -EIO;
  113. goto out;
  114. }
  115. out:
  116. return (ret);
  117. }
  118. static void DIVA_EXIT_FUNCTION divadidd_exit(void)
  119. {
  120. diddfunc_finit();
  121. remove_proc();
  122. printk(KERN_INFO "%s: module unloaded.\n", DRIVERLNAME);
  123. }
  124. module_init(divadidd_init);
  125. module_exit(divadidd_exit);