【Linux驱动技巧篇】如何使用延迟队列?

1. 创建延迟队列要绑定的延迟处理函数

void msm8952_pa_reset_func(struct work_struct *work)
{
	struct msm8916_asoc_mach_data *pdata = NULL;
	struct delayed_work *dwork;
	dwork = to_delayed_work(work);
	pdata = container_of(dwork, struct msm8916_asoc_mach_data, pa_reset_work);
	gpio_set_value(pdata->spk_ext_pa_sdb_gpio, GPIO_HIGH);
	gpio_set_value(pdata->spk_ext_pa_sdd_gpio, GPIO_HIGH);
}

2. 初始化队列并绑定延迟处理函数

INIT_DELAYED_WORK(&pdata->pa_reset_work, msm8952_pa_reset_func);

3. 在条件触发的地方调用该延迟队列

static int enable_spk_ext_pa(struct snd_soc_codec *codec, int enable)
{
	struct snd_soc_card *card = codec->component.card;
	struct msm8916_asoc_mach_data *pdata = snd_soc_card_get_drvdata(card);

	if(enable){
		schedule_delayed_work(&pdata->pa_reset_work, msecs_to_jiffies(20));
		pr_err("@@@@@@@@ ENABLE TPA @@@@@@@@@@@\n");
	} else {
		gpio_set_value(pdata->spk_ext_pa_sdd_gpio, GPIO_LOW);
		gpio_set_value(pdata->spk_ext_pa_sdb_gpio, GPIO_LOW);
		mdelay(100);
		pr_err("@@@@@@@@ DISABLE TPA @@@@@@@@@@\n");
	}
	return 0;
}

以后代码可以应用于解决音频功放造成的pop音问题。

发布了62 篇原创文章 · 获赞 66 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/crow_ch/article/details/103949243