Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 248247
b: refs/heads/master
c: 04368d0
h: refs/heads/master
i:
  248245: 7f4f2d5
  248243: 8cf226d
  248239: cb68eea
v: v3
  • Loading branch information
Marek Vasut authored and Mark Brown committed Apr 3, 2011
1 parent 437dbc6 commit e93e521
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 13 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 363618f013f2f11a1089b610748beb5de93b8630
refs/heads/master: 04368d051a6aa90c14a3ca5a48f60aca2f6ecdd1
41 changes: 29 additions & 12 deletions trunk/sound/soc/pxa/spitz.c
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@

static int spitz_jack_func;
static int spitz_spk_func;
static int spitz_mic_gpio;

static void spitz_ext_control(struct snd_soc_codec *codec)
{
Expand Down Expand Up @@ -217,14 +218,7 @@ static int spitz_set_spk(struct snd_kcontrol *kcontrol,
static int spitz_mic_bias(struct snd_soc_dapm_widget *w,
struct snd_kcontrol *k, int event)
{
if (machine_is_borzoi() || machine_is_spitz())
gpio_set_value(SPITZ_GPIO_MIC_BIAS,
SND_SOC_DAPM_EVENT_ON(event));

if (machine_is_akita())
gpio_set_value(AKITA_GPIO_MIC_BIAS,
SND_SOC_DAPM_EVENT_ON(event));

gpio_set_value_cansleep(spitz_mic_gpio, SND_SOC_DAPM_EVENT_ON(event));
return 0;
}

Expand Down Expand Up @@ -339,22 +333,45 @@ static int __init spitz_init(void)
if (!(machine_is_spitz() || machine_is_borzoi() || machine_is_akita()))
return -ENODEV;

if (machine_is_borzoi() || machine_is_spitz())
spitz_mic_gpio = SPITZ_GPIO_MIC_BIAS;
else
spitz_mic_gpio = AKITA_GPIO_MIC_BIAS;

ret = gpio_request(spitz_mic_gpio, "MIC GPIO");
if (ret)
goto err1;

ret = gpio_direction_output(spitz_mic_gpio, 0);
if (ret)
goto err2;

spitz_snd_device = platform_device_alloc("soc-audio", -1);
if (!spitz_snd_device)
return -ENOMEM;
if (!spitz_snd_device) {
ret = -ENOMEM;
goto err2;
}

platform_set_drvdata(spitz_snd_device, &snd_soc_spitz);
ret = platform_device_add(spitz_snd_device);

ret = platform_device_add(spitz_snd_device);
if (ret)
platform_device_put(spitz_snd_device);
goto err3;

return 0;

err3:
platform_device_put(spitz_snd_device);
err2:
gpio_free(spitz_mic_gpio);
err1:
return ret;
}

static void __exit spitz_exit(void)
{
platform_device_unregister(spitz_snd_device);
gpio_free(spitz_mic_gpio);
}

module_init(spitz_init);
Expand Down

0 comments on commit e93e521

Please sign in to comment.