Blame view

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

c6e3fd22c   William Hubbs   Staging: add spea...
147
148
149
150
151
  MODULE_AUTHOR("Kirk Reiser <kirk@braille.uwo.ca>");
  MODULE_AUTHOR("David Borowski");
  MODULE_DESCRIPTION("Speakup support for Accent SA synthesizer");
  MODULE_LICENSE("GPL");
  MODULE_VERSION(DRV_VERSION);