提交 2610df41 编写于 作者: S Samuel Thibault 提交者: Greg Kroah-Hartman

staging: speakup: Add pause command used on switching to graphical mode

For software speech syntheses to be able to manage concurrent audio card
access, they need to know when speakup stops emitting text to be spoken
because the console has switched to graphical mode.  This introduces a
PAUSE command to do so.
Signed-off-by: NSamuel Thibault <samuel.thibault@ens-lyon.org>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 a67cfe39
...@@ -77,6 +77,9 @@ void synth_buffer_add(u16 ch) ...@@ -77,6 +77,9 @@ void synth_buffer_add(u16 ch)
*buff_in++ = ch; *buff_in++ = ch;
if (buff_in > buffer_end) if (buff_in > buffer_end)
buff_in = synth_buffer; buff_in = synth_buffer;
/* We have written something to the speech synthesis, so we are not
* paused any more. */
spk_paused = 0;
} }
u16 synth_buffer_getc(void) u16 synth_buffer_getc(void)
......
...@@ -67,6 +67,8 @@ short spk_punc_mask; ...@@ -67,6 +67,8 @@ short spk_punc_mask;
int spk_punc_level, spk_reading_punc; int spk_punc_level, spk_reading_punc;
char spk_str_caps_start[MAXVARLEN + 1] = "\0"; char spk_str_caps_start[MAXVARLEN + 1] = "\0";
char spk_str_caps_stop[MAXVARLEN + 1] = "\0"; char spk_str_caps_stop[MAXVARLEN + 1] = "\0";
char spk_str_pause[MAXVARLEN + 1] = "\0";
bool spk_paused = 0;
const struct st_bits_data spk_punc_info[] = { const struct st_bits_data spk_punc_info[] = {
{"none", "", 0}, {"none", "", 0},
{"some", "/$%&@", SOME}, {"some", "/$%&@", SOME},
...@@ -1782,6 +1784,11 @@ static void speakup_con_update(struct vc_data *vc) ...@@ -1782,6 +1784,11 @@ static void speakup_con_update(struct vc_data *vc)
/* Speakup output, discard */ /* Speakup output, discard */
return; return;
speakup_date(vc); speakup_date(vc);
if (vc->vc_mode == KD_GRAPHICS && !spk_paused && spk_str_pause[0])
{
synth_printf("%s", spk_str_pause);
spk_paused = 1;
}
spin_unlock_irqrestore(&speakup_info.spinlock, flags); spin_unlock_irqrestore(&speakup_info.spinlock, flags);
} }
......
...@@ -94,7 +94,8 @@ extern struct spk_synth *synth; ...@@ -94,7 +94,8 @@ extern struct spk_synth *synth;
extern char spk_pitch_buff[]; extern char spk_pitch_buff[];
extern u_char *spk_our_keys[]; extern u_char *spk_our_keys[];
extern short spk_punc_masks[]; extern short spk_punc_masks[];
extern char spk_str_caps_start[], spk_str_caps_stop[]; extern char spk_str_caps_start[], spk_str_caps_stop[], spk_str_pause[];
extern bool spk_paused;
extern const struct st_bits_data spk_punc_info[]; extern const struct st_bits_data spk_punc_info[];
extern u_char spk_key_buf[600]; extern u_char spk_key_buf[600];
extern char *spk_characters[]; extern char *spk_characters[];
......
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
static struct var_t vars[] = { static struct var_t vars[] = {
{ CAPS_START, .u.s = {"CAPS_START\n" } }, { CAPS_START, .u.s = {"CAPS_START\n" } },
{ CAPS_STOP, .u.s = {"CAPS_STOP\n" } }, { CAPS_STOP, .u.s = {"CAPS_STOP\n" } },
{ PAUSE, .u.s = {"PAUSE\n"} },
{ RATE, .u.n = {"RATE %d\n", 8, 1, 16, 0, 0, NULL } }, { RATE, .u.n = {"RATE %d\n", 8, 1, 16, 0, 0, NULL } },
{ PITCH, .u.n = {"PITCH %d\n", 8, 0, 16, 0, 0, NULL } }, { PITCH, .u.n = {"PITCH %d\n", 8, 0, 16, 0, 0, NULL } },
{ VOL, .u.n = {"VOL %d\n", 8, 0, 16, 0, 0, NULL } }, { VOL, .u.n = {"VOL %d\n", 8, 0, 16, 0, 0, NULL } },
......
...@@ -35,6 +35,7 @@ static int misc_registered; ...@@ -35,6 +35,7 @@ static int misc_registered;
static struct var_t vars[] = { static struct var_t vars[] = {
{ CAPS_START, .u.s = {"\x01+3p" } }, { CAPS_START, .u.s = {"\x01+3p" } },
{ CAPS_STOP, .u.s = {"\x01-3p" } }, { CAPS_STOP, .u.s = {"\x01-3p" } },
{ PAUSE, .u.n = {"\x01P" } },
{ RATE, .u.n = {"\x01%ds", 2, 0, 9, 0, 0, NULL } }, { RATE, .u.n = {"\x01%ds", 2, 0, 9, 0, 0, NULL } },
{ PITCH, .u.n = {"\x01%dp", 5, 0, 9, 0, 0, NULL } }, { PITCH, .u.n = {"\x01%dp", 5, 0, 9, 0, 0, NULL } },
{ VOL, .u.n = {"\x01%dv", 5, 0, 9, 0, 0, NULL } }, { VOL, .u.n = {"\x01%dv", 5, 0, 9, 0, 0, NULL } },
...@@ -154,7 +155,7 @@ static char *get_initstring(void) ...@@ -154,7 +155,7 @@ static char *get_initstring(void)
var = synth_soft.vars; var = synth_soft.vars;
while (var->var_id != MAXVARS) { while (var->var_id != MAXVARS) {
if (var->var_id != CAPS_START && var->var_id != CAPS_STOP && if (var->var_id != CAPS_START && var->var_id != CAPS_STOP &&
var->var_id != DIRECT) var->var_id != PAUSE && var->var_id != DIRECT)
cp = cp + sprintf(cp, var->u.n.synth_fmt, cp = cp + sprintf(cp, var->u.n.synth_fmt,
var->u.n.value); var->u.n.value);
var++; var++;
......
...@@ -42,7 +42,7 @@ enum var_id_t { ...@@ -42,7 +42,7 @@ enum var_id_t {
SAY_CONTROL, SAY_WORD_CTL, NO_INTERRUPT, KEY_ECHO, SAY_CONTROL, SAY_WORD_CTL, NO_INTERRUPT, KEY_ECHO,
SPELL_DELAY, PUNC_LEVEL, READING_PUNC, SPELL_DELAY, PUNC_LEVEL, READING_PUNC,
ATTRIB_BLEEP, BLEEPS, ATTRIB_BLEEP, BLEEPS,
RATE, PITCH, VOL, TONE, PUNCT, VOICE, FREQUENCY, LANG, DIRECT, RATE, PITCH, VOL, TONE, PUNCT, VOICE, FREQUENCY, LANG, DIRECT, PAUSE,
CAPS_START, CAPS_STOP, CHARTAB, CAPS_START, CAPS_STOP, CHARTAB,
MAXVARS MAXVARS
}; };
......
...@@ -45,6 +45,7 @@ static struct st_var_header var_headers[] = { ...@@ -45,6 +45,7 @@ static struct st_var_header var_headers[] = {
{ "lang", LANG, VAR_NUM, NULL, NULL }, { "lang", LANG, VAR_NUM, NULL, NULL },
{ "chartab", CHARTAB, VAR_PROC, NULL, NULL }, { "chartab", CHARTAB, VAR_PROC, NULL, NULL },
{ "direct", DIRECT, VAR_NUM, NULL, NULL }, { "direct", DIRECT, VAR_NUM, NULL, NULL },
{ "pause", PAUSE, VAR_STRING, spk_str_pause, NULL },
}; };
static struct st_var_header *var_ptrs[MAXVARS] = { NULL, NULL, NULL }; static struct st_var_header *var_ptrs[MAXVARS] = { NULL, NULL, NULL };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册