From e4a3634c00818e77664da2c3592a95e8c8fad5d6 Mon Sep 17 00:00:00 2001 From: ryd Date: Tue, 19 Feb 2008 04:03:49 +0000 Subject: Adding .24 support for olpc kernel compiles fine, but graphic support is broken to test new kernel version, change target/linux/olpc/Makefile from .23.16 to .24 git-svn-id: svn://svn.openwrt.org/openwrt/trunk@10493 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- .../files/sound/pci/cs5535audio/cs5535audio_olpc.c | 110 --------------------- 1 file changed, 110 deletions(-) delete mode 100644 target/linux/olpc/files/sound/pci/cs5535audio/cs5535audio_olpc.c (limited to 'target/linux/olpc/files/sound/pci') diff --git a/target/linux/olpc/files/sound/pci/cs5535audio/cs5535audio_olpc.c b/target/linux/olpc/files/sound/pci/cs5535audio/cs5535audio_olpc.c deleted file mode 100644 index 791be73bf..000000000 --- a/target/linux/olpc/files/sound/pci/cs5535audio/cs5535audio_olpc.c +++ /dev/null @@ -1,110 +0,0 @@ -#include -#include -#include -#include -#include - -#include -#include "cs5535audio.h" - -/* - * OLPC has an additional feature on top of the regular AD1888 codec features. - * It has an Analog Input mode that is switched into (after disabling the - * High Pass Filter) via GPIO. It is only supported on B2 and later models. - */ - -int olpc_ai_enable(struct snd_ac97 *ac97, u8 val) -{ - int err; - - /* - * update the High Pass Filter (via AC97_AD_TEST2), and then set - * Analog Input mode through a GPIO. - */ - - if (val) { - err = snd_ac97_update_bits(ac97, AC97_AD_TEST2, - 1<type = SNDRV_CTL_ELEM_TYPE_BOOLEAN; - uinfo->count = 1; - uinfo->value.integer.min = 0; - uinfo->value.integer.max = 1; - return 0; -} - -static int snd_cs5535audio_ai_get(struct snd_kcontrol *kcontrol, - struct snd_ctl_elem_value *ucontrol) -{ - ucontrol->value.integer.value[0] = geode_gpio_isset(OLPC_GPIO_MIC_AC, - GPIO_OUTPUT_VAL); - return 0; -} - -static int snd_cs5535audio_ai_put(struct snd_kcontrol *kcontrol, - struct snd_ctl_elem_value *ucontrol) -{ - struct cs5535audio *cs5535au = snd_kcontrol_chip(kcontrol); - struct snd_ac97 *ac97 = cs5535au->ac97; - - olpc_ai_enable(ac97, ucontrol->value.integer.value[0]); - - return 1; -} - -static struct snd_kcontrol_new snd_cs5535audio_controls __devinitdata = -{ - .iface = SNDRV_CTL_ELEM_IFACE_MIXER, - .name = "DC Mode Enable", - .info = snd_cs5535audio_ai_info, - .get = snd_cs5535audio_ai_get, - .put = snd_cs5535audio_ai_put, - .private_value = 0 -}; - -void __devinit olpc_prequirks(struct snd_card *card, - struct snd_ac97_template *ac97) -{ - /* Bail if this isn't an OLPC platform */ - if (!machine_is_olpc()) - return; - - /* If on an OLPC B3 or higher, invert EAPD. */ - if (olpc_rev_after(OLPC_REV_B2)) - ac97->scaps |= AC97_SCAP_INV_EAPD; -} - -int __devinit olpc_quirks(struct snd_card *card, struct snd_ac97 *ac97) -{ - struct snd_ctl_elem_id elem; - - /* Bail if this isn't an OLPC platform */ - if (!machine_is_olpc()) - return 0; - - /* drop the original ad1888 HPF control */ - memset(&elem, 0, sizeof(elem)); - elem.iface = SNDRV_CTL_ELEM_IFACE_MIXER; - strcpy(elem.name, "High Pass Filter Enable"); - snd_ctl_remove_id(card, &elem); - - /* add the override for OLPC's HPF */ - return snd_ctl_add(card, snd_ctl_new1(&snd_cs5535audio_controls, - ac97->private_data)); -} -- cgit v1.2.3