Merge remote-tracking branches 'asoc/topic/rt5645', 'asoc/topic/rt5677', 'asoc/topic...
authorMark Brown <broonie@kernel.org>
Mon, 6 Oct 2014 11:49:03 +0000 (12:49 +0100)
committerMark Brown <broonie@kernel.org>
Mon, 6 Oct 2014 11:49:03 +0000 (12:49 +0100)
1  2  3  4  5  6 
sound/soc/codecs/rt5677.c

index dc978ad59fc78b91563235bf678919228b245e3a,67f14556462ff35bd6601062fc55a40ec2a96310,97dff7172fb625e981d31ca28df68ead41669299,67f14556462ff35bd6601062fc55a40ec2a96310,67f14556462ff35bd6601062fc55a40ec2a96310,67f14556462ff35bd6601062fc55a40ec2a96310..16aa4d99a71304ea20e1c108a9e90f1c61709e45
@@@@@@@ -3161,132 -3138,6 -3224,135 -3138,6 -3138,6 -3138,6 +3224,132 @@@@@@@ static int rt5677_set_bias_level(struc
        return 0;
      }
      
  -     int ret;
 + +++#ifdef CONFIG_GPIOLIB
 + +++static inline struct rt5677_priv *gpio_to_rt5677(struct gpio_chip *chip)
 + +++{
 + +++  return container_of(chip, struct rt5677_priv, gpio_chip);
 + +++}
 + +++
 + +++static void rt5677_gpio_set(struct gpio_chip *chip, unsigned offset, int value)
 + +++{
 + +++  struct rt5677_priv *rt5677 = gpio_to_rt5677(chip);
 + +++
 + +++  switch (offset) {
 + +++  case RT5677_GPIO1 ... RT5677_GPIO5:
 + +++          regmap_update_bits(rt5677->regmap, RT5677_GPIO_CTRL2,
 + +++                  0x1 << (offset * 3 + 1), !!value << (offset * 3 + 1));
 + +++          break;
 + +++
 + +++  case RT5677_GPIO6:
 + +++          regmap_update_bits(rt5677->regmap, RT5677_GPIO_CTRL3,
 + +++                  RT5677_GPIO6_OUT_MASK, !!value << RT5677_GPIO6_OUT_SFT);
 + +++          break;
 + +++
 + +++  default:
 + +++          break;
 + +++  }
 + +++}
 + +++
 + +++static int rt5677_gpio_direction_out(struct gpio_chip *chip,
 + +++                               unsigned offset, int value)
 + +++{
 + +++  struct rt5677_priv *rt5677 = gpio_to_rt5677(chip);
 + +++
 + +++  switch (offset) {
 + +++  case RT5677_GPIO1 ... RT5677_GPIO5:
 + +++          regmap_update_bits(rt5677->regmap, RT5677_GPIO_CTRL2,
 + +++                  0x3 << (offset * 3 + 1),
 + +++                  (0x2 | !!value) << (offset * 3 + 1));
 + +++          break;
 + +++
 + +++  case RT5677_GPIO6:
 + +++          regmap_update_bits(rt5677->regmap, RT5677_GPIO_CTRL3,
 + +++                  RT5677_GPIO6_DIR_MASK | RT5677_GPIO6_OUT_MASK,
 + +++                  RT5677_GPIO6_DIR_OUT | !!value << RT5677_GPIO6_OUT_SFT);
 + +++          break;
 + +++
 + +++  default:
 + +++          break;
 + +++  }
 + +++
 + +++  return 0;
 + +++}
 + +++
 + +++static int rt5677_gpio_get(struct gpio_chip *chip, unsigned offset)
 + +++{
 + +++  struct rt5677_priv *rt5677 = gpio_to_rt5677(chip);
 + +++  int value, ret;
 + +++
 + +++  ret = regmap_read(rt5677->regmap, RT5677_GPIO_ST, &value);
 + +++  if (ret < 0)
 + +++          return ret;
 + +++
 + +++  return (value & (0x1 << offset)) >> offset;
 + +++}
 + +++
 + +++static int rt5677_gpio_direction_in(struct gpio_chip *chip, unsigned offset)
 + +++{
 + +++  struct rt5677_priv *rt5677 = gpio_to_rt5677(chip);
 + +++
 + +++  switch (offset) {
 + +++  case RT5677_GPIO1 ... RT5677_GPIO5:
 + +++          regmap_update_bits(rt5677->regmap, RT5677_GPIO_CTRL2,
 + +++                  0x1 << (offset * 3 + 2), 0x0);
 + +++          break;
 + +++
 + +++  case RT5677_GPIO6:
 + +++          regmap_update_bits(rt5677->regmap, RT5677_GPIO_CTRL3,
 + +++                  RT5677_GPIO6_DIR_MASK, RT5677_GPIO6_DIR_IN);
 + +++          break;
 + +++
 + +++  default:
 + +++          break;
 + +++  }
 + +++
 + +++  return 0;
 + +++}
 + +++
 + +++static struct gpio_chip rt5677_template_chip = {
 + +++  .label                  = "rt5677",
 + +++  .owner                  = THIS_MODULE,
 + +++  .direction_output       = rt5677_gpio_direction_out,
 + +++  .set                    = rt5677_gpio_set,
 + +++  .direction_input        = rt5677_gpio_direction_in,
 + +++  .get                    = rt5677_gpio_get,
 + +++  .can_sleep              = 1,
 + +++};
 + +++
 + +++static void rt5677_init_gpio(struct i2c_client *i2c)
 + +++{
 + +++  struct rt5677_priv *rt5677 = i2c_get_clientdata(i2c);
 + +++  int ret;
 + +++
 + +++  rt5677->gpio_chip = rt5677_template_chip;
 + +++  rt5677->gpio_chip.ngpio = RT5677_GPIO_NUM;
 + +++  rt5677->gpio_chip.dev = &i2c->dev;
 + +++  rt5677->gpio_chip.base = -1;
 + +++
 + +++  ret = gpiochip_add(&rt5677->gpio_chip);
 + +++  if (ret != 0)
 + +++          dev_err(&i2c->dev, "Failed to add GPIOs: %d\n", ret);
 + +++}
 + +++
 + +++static void rt5677_free_gpio(struct i2c_client *i2c)
 + +++{
 + +++  struct rt5677_priv *rt5677 = i2c_get_clientdata(i2c);
  -     ret = gpiochip_remove(&rt5677->gpio_chip);
  -     if (ret != 0)
  -             dev_err(&i2c->dev, "Failed to remove GPIOs: %d\n", ret);
 + +++
 +++++  gpiochip_remove(&rt5677->gpio_chip);
 + +++}
 + +++#else
 + +++static void rt5677_init_gpio(struct i2c_client *i2c)
 + +++{
 + +++}
 + +++
 + +++static void rt5677_free_gpio(struct i2c_client *i2c)
 + +++{
 + +++}
 + +++#endif
 + +++
      static int rt5677_probe(struct snd_soc_codec *codec)
      {
        struct rt5677_priv *rt5677 = snd_soc_codec_get_drvdata(codec);
@@@@@@@ -3540,17 -3381,6 -3671,29 -3381,6 -3381,6 -3381,6 +3668,29 @@@@@@@ static int rt5677_i2c_probe(struct i2c_
                regmap_update_bits(rt5677->regmap, RT5677_IN1,
                                        RT5677_IN_DF2, RT5677_IN_DF2);
      
++ +++  if (rt5677->pdata.lout1_diff)
++ +++          regmap_update_bits(rt5677->regmap, RT5677_LOUT1,
++ +++                                  RT5677_LOUT1_L_DF, RT5677_LOUT1_L_DF);
++ +++
++ +++  if (rt5677->pdata.lout2_diff)
++ +++          regmap_update_bits(rt5677->regmap, RT5677_LOUT1,
++ +++                                  RT5677_LOUT2_L_DF, RT5677_LOUT2_L_DF);
++ +++
++ +++  if (rt5677->pdata.lout3_diff)
++ +++          regmap_update_bits(rt5677->regmap, RT5677_LOUT1,
++ +++                                  RT5677_LOUT3_L_DF, RT5677_LOUT3_L_DF);
++ +++
 + +++  if (rt5677->pdata.dmic2_clk_pin == RT5677_DMIC_CLK2) {
 + +++          regmap_update_bits(rt5677->regmap, RT5677_GEN_CTRL2,
 + +++                                  RT5677_GPIO5_FUNC_MASK,
 + +++                                  RT5677_GPIO5_FUNC_DMIC);
 + +++          regmap_update_bits(rt5677->regmap, RT5677_GPIO_CTRL2,
 + +++                                  RT5677_GPIO5_DIR_MASK,
 + +++                                  RT5677_GPIO5_DIR_OUT);
 + +++  }
 + +++
 + +++  rt5677_init_gpio(i2c);
 + +++
        return snd_soc_register_codec(&i2c->dev, &soc_codec_dev_rt5677,
                                      rt5677_dai, ARRAY_SIZE(rt5677_dai));
      }