speakup_acntsa.c 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. /*
  2. * originally written by: Kirk Reiser <kirk@braille.uwo.ca>
  3. * this version considerably modified by David Borowski, david575@rogers.com
  4. *
  5. * Copyright (C) 1998-99 Kirk Reiser.
  6. * Copyright (C) 2003 David Borowski.
  7. *
  8. * This program is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation; either version 2 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  21. *
  22. * this code is specificly written as a driver for the speakup screenreview
  23. * package and is not a general device driver.
  24. */
  25. #include "spk_priv.h"
  26. #include "speakup.h"
  27. #include "speakup_acnt.h" /* local header file for Accent values */
  28. #define DRV_VERSION "2.11"
  29. #define PROCSPEECH '\r'
  30. static int synth_probe(struct spk_synth *synth);
  31. static struct var_t vars[] = {
  32. { CAPS_START, .u.s = {"\033P8" } },
  33. { CAPS_STOP, .u.s = {"\033P5" } },
  34. { RATE, .u.n = {"\033R%c", 9, 0, 17, 0, 0, "0123456789abcdefgh" } },
  35. { PITCH, .u.n = {"\033P%d", 5, 0, 9, 0, 0, NULL } },
  36. { VOL, .u.n = {"\033A%d", 9, 0, 9, 0, 0, NULL } },
  37. { TONE, .u.n = {"\033V%d", 5, 0, 9, 0, 0, NULL } },
  38. { DIRECT, .u.n = {NULL, 0, 0, 1, 0, 0, NULL } },
  39. V_LAST_VAR
  40. };
  41. /*
  42. * These attributes will appear in /sys/accessibility/speakup/acntsa.
  43. */
  44. static struct kobj_attribute caps_start_attribute =
  45. __ATTR(caps_start, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  46. static struct kobj_attribute caps_stop_attribute =
  47. __ATTR(caps_stop, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  48. static struct kobj_attribute pitch_attribute =
  49. __ATTR(pitch, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  50. static struct kobj_attribute rate_attribute =
  51. __ATTR(rate, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  52. static struct kobj_attribute tone_attribute =
  53. __ATTR(tone, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  54. static struct kobj_attribute vol_attribute =
  55. __ATTR(vol, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  56. static struct kobj_attribute delay_time_attribute =
  57. __ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  58. static struct kobj_attribute direct_attribute =
  59. __ATTR(direct, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  60. static struct kobj_attribute full_time_attribute =
  61. __ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  62. static struct kobj_attribute jiffy_delta_attribute =
  63. __ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  64. static struct kobj_attribute trigger_time_attribute =
  65. __ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
  66. /*
  67. * Create a group of attributes so that we can create and destroy them all
  68. * at once.
  69. */
  70. static struct attribute *synth_attrs[] = {
  71. &caps_start_attribute.attr,
  72. &caps_stop_attribute.attr,
  73. &pitch_attribute.attr,
  74. &rate_attribute.attr,
  75. &tone_attribute.attr,
  76. &vol_attribute.attr,
  77. &delay_time_attribute.attr,
  78. &direct_attribute.attr,
  79. &full_time_attribute.attr,
  80. &jiffy_delta_attribute.attr,
  81. &trigger_time_attribute.attr,
  82. NULL, /* need to NULL terminate the list of attributes */
  83. };
  84. static struct spk_synth synth_acntsa = {
  85. .name = "acntsa",
  86. .version = DRV_VERSION,
  87. .long_name = "Accent-SA",
  88. .init = "\033T2\033=M\033Oi\033N1\n",
  89. .procspeech = PROCSPEECH,
  90. .clear = SYNTH_CLEAR,
  91. .delay = 400,
  92. .trigger = 50,
  93. .jiffies = 30,
  94. .full = 40000,
  95. .startup = SYNTH_START,
  96. .checkval = SYNTH_CHECK,
  97. .vars = vars,
  98. .probe = synth_probe,
  99. .release = spk_serial_release,
  100. .synth_immediate = spk_synth_immediate,
  101. .catch_up = spk_do_catch_up,
  102. .flush = spk_synth_flush,
  103. .is_alive = spk_synth_is_alive_restart,
  104. .synth_adjust = NULL,
  105. .read_buff_add = NULL,
  106. .get_index = NULL,
  107. .indexing = {
  108. .command = NULL,
  109. .lowindex = 0,
  110. .highindex = 0,
  111. .currindex = 0,
  112. },
  113. .attributes = {
  114. .attrs = synth_attrs,
  115. .name = "acntsa",
  116. },
  117. };
  118. static int synth_probe(struct spk_synth *synth)
  119. {
  120. int failed;
  121. failed = spk_serial_synth_probe(synth);
  122. if (failed == 0) {
  123. spk_synth_immediate(synth, "\033=R\r");
  124. mdelay(100);
  125. }
  126. synth->alive = !failed;
  127. return failed;
  128. }
  129. module_param_named(ser, synth_acntsa.ser, int, S_IRUGO);
  130. module_param_named(start, synth_acntsa.startup, short, S_IRUGO);
  131. MODULE_PARM_DESC(ser, "Set the serial port for the synthesizer (0-based).");
  132. MODULE_PARM_DESC(start, "Start the synthesizer once it is loaded.");
  133. module_spk_synth(synth_acntsa);
  134. MODULE_AUTHOR("Kirk Reiser <kirk@braille.uwo.ca>");
  135. MODULE_AUTHOR("David Borowski");
  136. MODULE_DESCRIPTION("Speakup support for Accent SA synthesizer");
  137. MODULE_LICENSE("GPL");
  138. MODULE_VERSION(DRV_VERSION);