88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore/*
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * CDDL HEADER START
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * The contents of this file are subject to the terms of the
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * Common Development and Distribution License (the "License").
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * You may not use this file except in compliance with the License.
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * or http://www.opensolaris.org/os/licensing.
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * See the License for the specific language governing permissions
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * and limitations under the License.
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * When distributing Covered Code, include this CDDL HEADER in each
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * If applicable, add the following below this CDDL HEADER, with the
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * fields enclosed by brackets "[]" replaced with your own identifying
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * information: Portions Copyright [yyyy] [name of copyright owner]
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * CDDL HEADER END
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore/*
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * Use is subject to license terms.
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore/*
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * ADS (Analog Devices) codec extensions.
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore/*
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * TODO:
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * Most vendors connect the surr-out of ad1980/ad1985 codecs to the
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * line-out jack. So far we haven't found which vendors don't
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * do that. So we assume that all vendors swap the surr-out
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * and the line-out outputs. So we need swap the two outputs.
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * Historically we internally processed the "ad198x-swap-output"
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * property. If someday some vendors do not swap the outputs, we would
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * set "ad198x-swap-output = 0" in the driver.conf file, and unload
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * and reload the driver (or reboot).
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * TODO:
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * Since we don't have access (at present) to any such systems, we have
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * not implemented this swapping property. Once we can test it, we will
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * add it. This is noted as CR 6819556.
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * The old code did this:
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * if (ddi_prop_get_int(DDI_DEV_T_ANY, statep->dip,
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * DDI_PROP_DONTPASS, "ad198x-swap-output", 1) == 1) {
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * statep->swap_out = B_TRUE;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * (void) audioixp_read_ac97(statep, CODEC_AD_REG_MISC, &tmp);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * (void) audioixp_write_ac97(statep,
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * CODEC_AD_REG_MISC,
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore * tmp | AD1980_MISC_LOSEL | AD1980_MISC_HPSEL);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore *
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#include <sys/types.h>
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#include <sys/ddi.h>
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#include <sys/sunddi.h>
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#include <sys/audio/audio_driver.h>
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#include <sys/audio/ac97.h>
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#include <sys/note.h>
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#include "ac97_impl.h"
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ADS_EQ_CTRL_REGISTER 0x60
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AECR_EQM 0x8000 /* disable EQ */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AECR_SYM 0x0080
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ADS_EQ_DATA_REGISTER 0x62
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ADS_MIXER_ADC_IGAIN_REGISTER 0x64
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMADIR_LEFT_MASK 0x0f00
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMADIR_RIGHT_MASK 0x000f
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMADIR_MXM 0x8000
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ADS_JS_INTS_STATUS_REGISTER 0x72
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JS0INT 0x0001
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JS1INT 0x0002
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JS0ST 0x0004
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JS1ST 0x0008
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JS0MD 0x0010
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JS1MD 0x0020
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JS0TMR 0x0040
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JS1TMR 0x0080
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JS0EQB 0x0100
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JS1EQB 0x0200
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JSMT_MASK 0x1c00
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JSMT_NONE 0x0000
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JSMT_HP_LNOUT 0x0400 /* hp mutes line out */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JSMT_HP_BOTH 0x0800 /* hp mutes both mono & line */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JSMT_LNOUT_MONO 0x1000 /* lineout mutes mono */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AJISR_JSMT_ALL 0x1800 /* all JS muting enabled */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ADS_SERIAL_CFG_REGISTER 0x74
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ASCR_SPLNK 0x0001
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ASCR_SPDZ 0x0002
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ASCR_SPAL 0x0004
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ASCR_INTS 0x0010
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ASCR_CHEN 0x0100
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ASCR_REGM0 0x1000
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ASCR_REGM1 0x2000
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ASCR_REGM2 0x4000
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ASCR_SLOT16 0x8000
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define ADS_MISC_CFG_REGISTER 0x76
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_MBG_MASK 0x0003
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_MBG_20dB 0x0000
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_MBG_10dB 0x0001
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_MBG_30dB 0x0002
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_VREFD 0x0004
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_VREFH 0x0008
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_MADST 0x0010 /* AD1981B */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_SRU 0x0010 /* AD1980 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_LOSEL 0x0020 /* AD1980 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_2CMIC 0x0040
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_MADPD 0x0080 /* AD1981B */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_SPRD 0x0080 /* AD1980 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_DMIX_6TO2 0x0100 /* AD1980 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_DMIX_FORCE 0x0200 /* AD1980 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_FMXE 0x0200 /* AD1981B */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_HPSEL 0x0400 /* AD1980 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_CLDIS 0x0800 /* AD1980 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_LODIS 0x1000 /* AD1980 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_DAM 0x0800 /* AD1981B */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_MSPLT 0x2000
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_AC97NC 0x4000 /* AD1980 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore#define AMCR_DACZ 0x8000
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amorestatic void
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amoreads_set_micboost(ac97_ctrl_t *actrl, uint64_t value)
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore{
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore ac97_t *ac = actrl->actrl_ac97;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore uint16_t v;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_wr(ac, AC97_INTERRUPT_PAGING_REGISTER, 0); /* select page 0 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore switch (value) {
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore case 0x1:
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore /* 0db */
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_clr(ac, AC97_MIC_VOLUME_REGISTER, MICVR_20dB_BOOST);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore break;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore case 0x2:
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore /* 10dB */
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_set(ac, AC97_MIC_VOLUME_REGISTER, MICVR_20dB_BOOST);
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore v = ac_rd(ac, ADS_MISC_CFG_REGISTER);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore v &= ~AMCR_MBG_MASK;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore v |= AMCR_MBG_10dB;
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_wr(ac, ADS_MISC_CFG_REGISTER, v);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore break;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore case 0x4:
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore /* 20dB */
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_set(ac, AC97_MIC_VOLUME_REGISTER, MICVR_20dB_BOOST);
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore v = ac_rd(ac, ADS_MISC_CFG_REGISTER);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore v &= ~AMCR_MBG_MASK;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore v |= AMCR_MBG_20dB;
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_wr(ac, ADS_MISC_CFG_REGISTER, v);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore break;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore case 0x8:
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore /* 30dB */
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_set(ac, AC97_MIC_VOLUME_REGISTER, MICVR_20dB_BOOST);
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore v = ac_rd(ac, ADS_MISC_CFG_REGISTER);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore v &= ~AMCR_MBG_MASK;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore v |= AMCR_MBG_30dB;
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_wr(ac, ADS_MISC_CFG_REGISTER, v);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore break;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore }
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore}
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amorestatic void
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amoreads_set_micsrc(ac97_ctrl_t *actrl, uint64_t value)
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore{
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore ac97_t *ac = actrl->actrl_ac97;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_wr(ac, AC97_INTERRUPT_PAGING_REGISTER, 0); /* select page 0 */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore switch (value) {
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore case 0x1: /* mic1 */
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_clr(ac, ADS_MISC_CFG_REGISTER, AMCR_2CMIC);
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_clr(ac, AC97_GENERAL_PURPOSE_REGISTER, GPR_MS_MIC2);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore break;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore case 0x2: /* mic2 */
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_clr(ac, ADS_MISC_CFG_REGISTER, AMCR_2CMIC);
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_set(ac, AC97_GENERAL_PURPOSE_REGISTER, GPR_MS_MIC2);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore break;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore case 0x4: /* stereo - ms bit clear to allow MIC1 to be mixed */
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_set(ac, ADS_MISC_CFG_REGISTER, AMCR_2CMIC);
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_clr(ac, AC97_GENERAL_PURPOSE_REGISTER, GPR_MS_MIC2);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore break;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore }
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore}
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amorestatic void
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amoreads_setup_micsrc(ac97_t *ac)
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore{
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore static const char *values[] = {
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AUDIO_PORT_MIC1,
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AUDIO_PORT_MIC2,
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AUDIO_PORT_STEREO,
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore NULL
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore };
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore ac97_ctrl_probe_t cpt = {
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AUDIO_CTRL_ID_MICSRC, 1, 0x7, 0x7, AUDIO_CTRL_TYPE_ENUM,
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AC97_FLAGS | AUDIO_CTRL_FLAG_REC, 0, ads_set_micsrc,
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore NULL, 0, values };
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_add_control(ac, &cpt);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore}
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amorestatic void
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amoreads_setup_micboost(ac97_t *ac)
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore{
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore ac97_ctrl_t *ctrl;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore static const char *values[] = {
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AUDIO_VALUE_OFF, /* 0dB */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AUDIO_VALUE_LOW, /* 10dB */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AUDIO_VALUE_MEDIUM, /* 20dB */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AUDIO_VALUE_HIGH, /* 30dB */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore NULL
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore };
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore ac97_ctrl_probe_t cpt = {
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AUDIO_CTRL_ID_MICBOOST, 1, 0xf, 0xf, AUDIO_CTRL_TYPE_ENUM,
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore AC97_FLAGS | AUDIO_CTRL_FLAG_REC, 0, ads_set_micboost,
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore NULL, 0, values };
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore ctrl = ac97_control_find(ac, AUDIO_CTRL_ID_MICBOOST);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore if (ctrl) {
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore if (ctrl->actrl_initval) {
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore /* 20dB by default */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore cpt.cp_initval = 2;
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore }
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore }
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
33ab04ab97e6a2ee82971255446a0aa4eace756eGarrett D'Amore ac_add_control(ac, &cpt);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore}
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amorevoid
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amoread1981a_init(ac97_t *ac)
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore{
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore ads_setup_micboost(ac);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore}
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amorevoid
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amoread1981b_init(ac97_t *ac)
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore{
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore ads_setup_micboost(ac);
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore ads_setup_micsrc(ac); /* this part can use a mic array */
88447a05f537aabe9a1bc3d5313f22581ec992a7Garrett D'Amore}