res = generate(chan, tmp, 0, ast_format_rate(chan->writeformat & AST_FORMAT_AUDIO_MASK) / 50);
- chan->generatordata = tmp;
+ ast_channel_lock(chan);
+ if (chan->generator && generate == chan->generator->generate) {
+ chan->generatordata = tmp;
+ }
+ ast_channel_unlock(chan);
if (res) {
ast_debug(1, "Auto-deactivating generator\n");
return state;
}
+static int internal_deactivate_generator(struct ast_channel *chan, void* generator)
+{
+ ast_channel_lock(chan);
+
+ if (!chan->generatordata) {
+ ast_debug(1, "Trying to stop silence generator when there is no "
+ "generator on '%s'\n", chan->name);
+ ast_channel_unlock(chan);
+ return 0;
+ }
+ if (chan->generator != generator) {
+ ast_debug(1, "Trying to stop silence generator when it is not the current "
+ "generator on '%s'\n", chan->name);
+ ast_channel_unlock(chan);
+ return 0;
+ }
+ if (chan->generator && chan->generator->release) {
+ chan->generator->release(chan, chan->generatordata);
+ }
+ chan->generatordata = NULL;
+ chan->generator = NULL;
+ ast_channel_set_fd(chan, AST_GENERATOR_FD, -1);
+ ast_clear_flag(chan, AST_FLAG_WRITE_INT);
+ ast_settimeout(chan, 0, NULL, NULL);
+ ast_channel_unlock(chan);
+
+ return 1;
+}
+
void ast_channel_stop_silence_generator(struct ast_channel *chan, struct ast_silence_generator *state)
{
if (!state)
return;
- ast_deactivate_generator(chan);
-
- ast_debug(1, "Stopped silence generator on '%s'\n", chan->name);
-
- if (ast_set_write_format(chan, state->old_write_format) < 0)
- ast_log(LOG_ERROR, "Could not return write format to its original state\n");
+ if (internal_deactivate_generator(chan, &silence_generator)) {
+ ast_debug(1, "Stopped silence generator on '%s'\n", chan->name);
+ if (ast_set_write_format(chan, state->old_write_format) < 0)
+ ast_log(LOG_ERROR, "Could not return write format to its original state\n");
+ }
ast_free(state);
}