zoukankan      html  css  js  c++  java
  • tas5721 驱动

    Submitter Mark Brown
    Date March 31, 2016, 5:33 p.m.
    Message ID <E1algTO-0004Cm-Ga@finisterre>
    Download mbox | patch
    Permalink /patch/8715141/
    State New
    Headers show
     

    Comments

    Mark Brown - March 31, 2016, 5:33 p.m.
    The patch
    
       ASoC: tas571x: added support for TAS5721
    
    has been applied to the asoc tree at
    
       git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound.git 
    
    All being well this means that it will be integrated into the linux-next
    tree (usually sometime in the next 24 hours) and sent to Linus during
    the next merge window (or sooner if it is a bug fix), however if
    problems are discovered then the patch may be dropped or reverted.  
    
    You may get further e-mails resulting from automated or manual testing
    and review of the tree, please engage with people reporting problems and
    send followup patches addressing any issues that are reported if needed.
    
    If any updates are required or you are submitting further changes they
    should be sent as incremental updates against current git, existing
    patches will not be replaced.
    
    Please add any relevant lists and maintainers to the CCs when replying
    to this mail.
    
    Thanks,
    Mark
    
    From 23a282c4f088efb337957ffa21c677d30eda0784 Mon Sep 17 00:00:00 2001
    From: Petr Kulhavy <petr@barix.com>
    Date: Thu, 31 Mar 2016 18:41:26 +0200
    Subject: [PATCH] ASoC: tas571x: added support for TAS5721
    
    This adds support for TAS5721.
    
    Signed-off-by: Petr Kulhavy <petr@barix.com>
    Signed-off-by: Mark Brown <broonie@kernel.org>
    ---
     sound/soc/codecs/Kconfig   |  2 +-
     sound/soc/codecs/tas571x.c | 76 ++++++++++++++++++++++++++++++++++++++++++++++
     2 files changed, 77 insertions(+), 1 deletion(-)

    diff --git a/sound/soc/codecs/Kconfig b/sound/soc/codecs/Kconfig
    index 649e92a252ae..c011f076d58b 100644
    --- a/sound/soc/codecs/Kconfig
    +++ b/sound/soc/codecs/Kconfig
    @@ -737,7 +737,7 @@  config SND_SOC_TAS5086
         depends on I2C
     
     config SND_SOC_TAS571X
    -    tristate "Texas Instruments TAS5711/TAS5717/TAS5719 power amplifiers"
    +    tristate "Texas Instruments TAS5711/TAS5717/TAS5719/TAS5721 power amplifiers"
         depends on I2C
     
     config SND_SOC_TFA9879
    diff --git a/sound/soc/codecs/tas571x.c b/sound/soc/codecs/tas571x.c
    index ef6c8d9b251a..b8d19b77bde9 100644
    --- a/sound/soc/codecs/tas571x.c
    +++ b/sound/soc/codecs/tas571x.c
    @@ -4,6 +4,9 @@ 
      * Copyright (C) 2015 Google, Inc.
      * Copyright (c) 2013 Daniel Mack <zonque@gmail.com>
      *
    + * TAS5721 support:
    + * Copyright (C) 2016 Petr Kulhavy, Barix AG <petr@barix.com>
    + *
      * 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
    @@ -372,6 +375,77 @@  static const struct tas571x_chip tas5717_chip = {
         .vol_reg_size            = 2,
     };
     
    +static const char *const tas5721_supply_names[] = {
    +    "AVDD",
    +    "DVDD",
    +    "DRVDD",
    +    "PVDD",
    +};
    +
    +static const struct snd_kcontrol_new tas5721_controls[] = {
    +    SOC_SINGLE_TLV("Master Volume",
    +               TAS571X_MVOL_REG,
    +               0, 0xff, 1, tas5711_volume_tlv),
    +    SOC_DOUBLE_R_TLV("Speaker Volume",
    +             TAS571X_CH1_VOL_REG,
    +             TAS571X_CH2_VOL_REG,
    +             0, 0xff, 1, tas5711_volume_tlv),
    +    SOC_DOUBLE("Speaker Switch",
    +           TAS571X_SOFT_MUTE_REG,
    +           TAS571X_SOFT_MUTE_CH1_SHIFT, TAS571X_SOFT_MUTE_CH2_SHIFT,
    +           1, 1),
    +};
    +
    +static const struct reg_default tas5721_reg_defaults[] = {
    +    {TAS571X_CLK_CTRL_REG,        0x6c},
    +    {TAS571X_DEV_ID_REG,        0x00},
    +    {TAS571X_ERR_STATUS_REG,    0x00},
    +    {TAS571X_SYS_CTRL_1_REG,    0xa0},
    +    {TAS571X_SDI_REG,        0x05},
    +    {TAS571X_SYS_CTRL_2_REG,    0x40},
    +    {TAS571X_SOFT_MUTE_REG,        0x00},
    +    {TAS571X_MVOL_REG,        0xff},
    +    {TAS571X_CH1_VOL_REG,        0x30},
    +    {TAS571X_CH2_VOL_REG,        0x30},
    +    {TAS571X_CH3_VOL_REG,        0x30},
    +    {TAS571X_VOL_CFG_REG,        0x91},
    +    {TAS571X_MODULATION_LIMIT_REG,    0x02},
    +    {TAS571X_IC_DELAY_CH1_REG,    0xac},
    +    {TAS571X_IC_DELAY_CH2_REG,    0x54},
    +    {TAS571X_IC_DELAY_CH3_REG,    0xac},
    +    {TAS571X_IC_DELAY_CH4_REG,    0x54},
    +    {TAS571X_PWM_CH_SDN_GROUP_REG,    0x30},
    +    {TAS571X_START_STOP_PERIOD_REG,    0x0f},
    +    {TAS571X_OSC_TRIM_REG,        0x82},
    +    {TAS571X_BKND_ERR_REG,        0x02},
    +    {TAS571X_INPUT_MUX_REG,        0x17772},
    +    {TAS571X_CH4_SRC_SELECT_REG,    0x4303},
    +    {TAS571X_PWM_MUX_REG,        0x1021345},
    +};
    +
    +static const struct regmap_config tas5721_regmap_config = {
    +    .reg_bits            = 8,
    +    .val_bits            = 32,
    +    .max_register            = 0xff,
    +    .reg_read            = tas571x_reg_read,
    +    .reg_write            = tas571x_reg_write,
    +    .reg_defaults            = tas5721_reg_defaults,
    +    .num_reg_defaults        = ARRAY_SIZE(tas5721_reg_defaults),
    +    .cache_type            = REGCACHE_RBTREE,
    +    .wr_table            = &tas571x_write_regs,
    +    .volatile_table            = &tas571x_volatile_regs,
    +};
    +
    +
    +static const struct tas571x_chip tas5721_chip = {
    +    .supply_names            = tas5721_supply_names,
    +    .num_supply_names        = ARRAY_SIZE(tas5721_supply_names),
    +    .controls            = tas5711_controls,
    +    .num_controls            = ARRAY_SIZE(tas5711_controls),
    +    .regmap_config            = &tas5721_regmap_config,
    +    .vol_reg_size            = 1,
    +};
    +
     static const struct snd_soc_dapm_widget tas571x_dapm_widgets[] = {
         SND_SOC_DAPM_DAC("DACL", NULL, SND_SOC_NOPM, 0, 0),
         SND_SOC_DAPM_DAC("DACR", NULL, SND_SOC_NOPM, 0, 0),
    @@ -527,6 +601,7 @@  static const struct of_device_id tas571x_of_match[] = {
         { .compatible = "ti,tas5711", .data = &tas5711_chip, },
         { .compatible = "ti,tas5717", .data = &tas5717_chip, },
         { .compatible = "ti,tas5719", .data = &tas5717_chip, },
    +    { .compatible = "ti,tas5721", .data = &tas5721_chip, },
         { }
     };
     MODULE_DEVICE_TABLE(of, tas571x_of_match);
    @@ -535,6 +610,7 @@  static const struct i2c_device_id tas571x_i2c_id[] = {
         { "tas5711", (kernel_ulong_t) &tas5711_chip },
         { "tas5717", (kernel_ulong_t) &tas5717_chip },
         { "tas5719", (kernel_ulong_t) &tas5717_chip },
    +    { "tas5721", (kernel_ulong_t) &tas5721_chip },
         { }
     };
     MODULE_DEVICE_TABLE(i2c, tas571x_i2c_id);
     
  • 相关阅读:
    解决 EDAS:Upload failed: The right margin is 0.535 in on page 1 问题
    解决 ImportError: No module named _internal
    静态页面如何实现 include 引入公用代码
    一个用 js 实现点阵图的编辑器演示
    从 art-template 模版维护到动态加载的思考
    Atom 备份神器 —— Sync Settings
    clicaptcha中文点击验证码开发经验总结
    通过 imagick 让 PHP 生成 PSD 文件缩略图
    让视频压制更简单
    Medoo个人修改版
  • 原文地址:https://www.cnblogs.com/muhuacat/p/5799048.html
Copyright © 2011-2022 走看看