1、添加關鍵頭文件:

#include <linux/of_gpio.h>
#include <linux/gpio.h>
#include <linux/delay.h>

#include <linux/module.h>
#include <linux/types.h>
#include <linux/kobject.h>

2、定義全局變量和定義打開和關閉的接口并組織屬性數組:

// add zhaojr gpio63 for close or speaker pa enable
struct kobject *spk_pa_kobj = NULL;
unsigned int gpio63_spk_pa_gpio; //for speaker pa ic enable
//extern unsigned int gpio63_spk_pa_gpio;
static unsigned int SpkPa_Gpio_Enable = 0;
static ssize_t spkpaon_store(struct device *dev, struct device_attribute *attr,const char *buf, size_t count)  
{
 unsigned int ret=0;
 //ret = kstrtoint(buf, 10, &backlight_enable);
 ret = kstrtouint(buf, 10, &SpkPa_Gpio_Enable);
 if (ret < 0){
 pr_err(%s::kstrtouint() failed \\\\n, __func__);
 }
 pr_err(%s: SpkPa_Gpio_Enable=%d \\\\n, __func__,SpkPa_Gpio_Enable); 
 if(SpkPa_Gpio_Enable > 0){
 //gpio_set_value(gpio63_spk_pa_gpio, 1); 
 pr_err(%s: gpio_set_value gpio63 speaker pa enable \\\\n, __func__);
 //功放打開的時序
 gpio_set_value(gpio63_spk_pa_gpio,0);
 udelay(8);
 gpio_set_value(gpio63_spk_pa_gpio,1);
 udelay(8);
 gpio_set_value(gpio63_spk_pa_gpio,0);
 udelay(8);
 gpio_set_value(gpio63_spk_pa_gpio,1);
 //sdm660_cdc->ext_spk_pa_set = true;
 }else{
 pr_err(%s: gpio_set_value gpio63 speaker pa disable \\\\n, __func__);
 //功放關閉的時序
 gpio_set_value(gpio63_spk_pa_gpio,0);
 udelay(600);
 //sdm660_cdc->ext_spk_pa_set = false; 
 }
 return count;
}
static ssize_t spkpaon_show(struct device *dev,struct device_attribute *attr, char *buf) 
{ 
 return sprintf(buf, %d\\\\n,SpkPa_Gpio_Enable);
} 
static DEVICE_ATTR(spkpaon, 0664, spkpaon_show, spkpaon_store);
static struct attribute *spkpa_attributes[] = {
 &dev_attr_spkpaon.attr,
 NULL
};
static const struct attribute_group apkpa_attr_group = {
 .attrs = spkpa_attributes,
 NULL
};
//end zhaojr add

3、在probe()函數中添加文件系統屬性接口的注冊:
在注冊的時候并不需要對功放進行初始化,所以probe()函數中并沒有對sdm660_cdc->spk_pa_gpio(GPIO63),只操作了請求。具體的請求操作請參考:msm8953 audio部分的EAR和Speaker輸出的聲音配置中的音頻部分的

vendor/qcom/opensource/audio-kernel/asoc/codecs/sdm660_cdc/msm-analog-cdc.c文件操作

static int msm_anlg_cdc_probe(struct platform_device *pdev)
{
 int ret = 0;
 struct sdm660_cdc_priv *sdm660_cdc = NULL;
 struct sdm660_cdc_pdata *pdata;
 int adsp_state;
 ..................................
 dev_set_drvdata(&pdev->dev, sdm660_cdc);
 //kangting add
 sdm660_cdc->spk_pa_gpio = of_get_named_gpio(pdev->dev.of_node, qcom,speaker-pa, 0);
 if (!gpio_is_valid(sdm660_cdc->spk_pa_gpio))
 pr_err(%s, sdm660_cdc->spk_pa_gpio not specified\\\\n,__func__);
 else{
 pr_err(%s, sdm660_cdc->spk_pa_gpio is %d\\\\n,__func__,sdm660_cdc->spk_pa_gpio);
 ret = gpio_request(sdm660_cdc->spk_pa_gpio, spk_pa);
 if (ret) {
 pr_err(request spk_pa_gpio failed, ret=%d\\\\n,ret);
 gpio_free(sdm660_cdc->spk_pa_gpio);
 }
 }
 //kangting end
 ret = snd_soc_register_codec(&pdev->dev,
   &soc_codec_dev_sdm660_cdc,
   msm_anlg_cdc_i2s_dai,
   ARRAY_SIZE(msm_anlg_cdc_i2s_dai));
 if (ret) {
 dev_err(&pdev->dev,
 %s:snd_soc_register_codec failed with error %d\\\\n,
 __func__, ret);
 goto err_supplies;
 }
 BLOCKING_INIT_NOTIFIER_HEAD(&sdm660_cdc->notifier);
 BLOCKING_INIT_NOTIFIER_HEAD(&sdm660_cdc->notifier_mbhc);
 //add by zhaojr
 gpio63_spk_pa_gpio = sdm660_cdc->spk_pa_gpio; //將設備樹種定義的IO口號獲取進來
 spk_pa_kobj = kobject_create_and_add(spk_pa, NULL); //創建/sys/spk_pa/目錄
 ret = sysfs_create_group(spk_pa_kobj, &apkpa_attr_group); //創建/sys/class/spk_pa/spkpaon節點
 if (ret)
 dev_err(&pdev->dev,%s:sysfs_create_group failed with error\\\\n,__func__);
 //end zhaojr add 
 ....................................

4、在remove函數中釋放資源

static int msm_anlg_cdc_remove(struct platform_device *pdev)
{
 struct sdm660_cdc_priv *sdm660_cdc = dev_get_drvdata(&pdev->dev);
 struct sdm660_cdc_pdata *pdata = sdm660_cdc->dev->platform_data;
 int count;
 //add by zhaojr //釋放資源
 gpio_free(sdm660_cdc->spk_pa_gpio);
 kobject_put(spk_pa_kobj); //關鍵函數
 sysfs_remove_group(spk_pa_kobj, &apkpa_attr_group); //關鍵函數
 //end zhaojr add
 for (count = 0; count < sdm660_cdc->child_count &&
 count < ANLG_CDC_CHILD_DEVICES_MAX; count  )
 platform_device_unregister(
 sdm660_cdc->pdev_child_devices[count]);
 snd_soc_unregister_codec(&pdev->dev);
 msm_anlg_cdc_disable_supplies(sdm660_cdc, pdata);
 wcd9xxx_spmi_irq_exit();
 devm_kfree(&pdev->dev, sdm660_cdc);
 return 0;
}

總結

到此這篇關于解析linux或android添加文件系統的屬性接口的方法的文章就介紹到這了,更多相關linux 文件系統的屬性接口內容請搜索三五互聯以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持三五互聯

更多關于云服務器域名注冊,虛擬主機的問題,請訪問三五互聯官網:m.shinetop.cn

贊(0)
聲明:本網站發布的內容(圖片、視頻和文字)以原創、轉載和分享網絡內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。郵箱:3140448839@qq.com。本站原創內容未經允許不得轉載,或轉載時需注明出處:三五互聯知識庫 » 解析linux或android添加文件系統的屬性接口的方法

登錄

找回密碼

注冊

主站蜘蛛池模板: 一女被多男玩喷潮视频| 成人午夜av在线播放| 国产精品综合一区二区三区| 国产精品一区二区小视频| 国产人成精品一区二区三| 国产农村老太xxxxhdxx| 最新国产精品精品视频| 无码三级av电影在线观看| 巨爆乳中文字幕爆乳区| 丰满爆乳一区二区三区| 97人妻精品一区二区三区| 久久国产热这里只有精品| 免费VA国产高清大片在线| 四虎在线成人免费观看| 久久羞羞色院精品全部免费| 精品无码成人片一区二区| 中文字幕av无码一区二区三区| 亚洲国产成人精品区综合| 新久久国产色av免费看| 九九re线精品视频在线观看视频 | 四虎精品视频永久免费| 欧美高清一区三区在线专区| 野外做受三级视频| 国产亚洲精品久久综合阿香| 亚洲AV熟妇在线观看| 99精品国产高清一区二区麻豆 | 亚洲一区二区精品动漫| 一区二区三区鲁丝不卡| 日韩在线观看精品亚洲| 熟女丰满老熟女熟妇| 高潮射精日本韩国在线播放| 一区二区不卡国产精品| 国产在线线精品宅男网址| 国产在线线精品宅男网址| 国产午夜福利视频一区二区| 在线高清理伦片a| 中文字幕亚洲中文字幕无码码| 久久丁香五月天综合网| 亚洲av免费看一区二区| 97精品伊人久久久大香线蕉| 日本边添边摸边做边爱|