linux/include/sound/wm8903.h

/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * linux/sound/wm8903.h -- Platform data for WM8903
 *
 * Copyright 2010 Wolfson Microelectronics. PLC.
 */

#ifndef __LINUX_SND_WM8903_H
#define __LINUX_SND_WM8903_H

/*
 * Used to enable configuration of a GPIO to all zeros; a gpio_cfg value of
 * zero in platform data means "don't touch this pin".
 */
#define WM8903_GPIO_CONFIG_ZERO

/*
 * R6 (0x06) - Mic Bias Control 0
 */
#define WM8903_MICDET_THR_MASK
#define WM8903_MICDET_THR_SHIFT
#define WM8903_MICDET_THR_WIDTH
#define WM8903_MICSHORT_THR_MASK
#define WM8903_MICSHORT_THR_SHIFT
#define WM8903_MICSHORT_THR_WIDTH
#define WM8903_MICDET_ENA
#define WM8903_MICDET_ENA_MASK
#define WM8903_MICDET_ENA_SHIFT
#define WM8903_MICDET_ENA_WIDTH
#define WM8903_MICBIAS_ENA
#define WM8903_MICBIAS_ENA_MASK
#define WM8903_MICBIAS_ENA_SHIFT
#define WM8903_MICBIAS_ENA_WIDTH

/*
 * WM8903_GPn_FN values
 *
 * See datasheets for list of valid values per pin
 */
#define WM8903_GPn_FN_GPIO_OUTPUT
#define WM8903_GPn_FN_BCLK
#define WM8903_GPn_FN_IRQ_OUTPT
#define WM8903_GPn_FN_GPIO_INPUT
#define WM8903_GPn_FN_MICBIAS_CURRENT_DETECT
#define WM8903_GPn_FN_MICBIAS_SHORT_DETECT
#define WM8903_GPn_FN_DMIC_LR_CLK_OUTPUT
#define WM8903_GPn_FN_FLL_LOCK_OUTPUT
#define WM8903_GPn_FN_FLL_CLOCK_OUTPUT

/*
 * R116 (0x74) - GPIO Control 1
 */
#define WM8903_GP1_FN_MASK
#define WM8903_GP1_FN_SHIFT
#define WM8903_GP1_FN_WIDTH
#define WM8903_GP1_DIR
#define WM8903_GP1_DIR_MASK
#define WM8903_GP1_DIR_SHIFT
#define WM8903_GP1_DIR_WIDTH
#define WM8903_GP1_OP_CFG
#define WM8903_GP1_OP_CFG_MASK
#define WM8903_GP1_OP_CFG_SHIFT
#define WM8903_GP1_OP_CFG_WIDTH
#define WM8903_GP1_IP_CFG
#define WM8903_GP1_IP_CFG_MASK
#define WM8903_GP1_IP_CFG_SHIFT
#define WM8903_GP1_IP_CFG_WIDTH
#define WM8903_GP1_LVL
#define WM8903_GP1_LVL_MASK
#define WM8903_GP1_LVL_SHIFT
#define WM8903_GP1_LVL_WIDTH
#define WM8903_GP1_PD
#define WM8903_GP1_PD_MASK
#define WM8903_GP1_PD_SHIFT
#define WM8903_GP1_PD_WIDTH
#define WM8903_GP1_PU
#define WM8903_GP1_PU_MASK
#define WM8903_GP1_PU_SHIFT
#define WM8903_GP1_PU_WIDTH
#define WM8903_GP1_INTMODE
#define WM8903_GP1_INTMODE_MASK
#define WM8903_GP1_INTMODE_SHIFT
#define WM8903_GP1_INTMODE_WIDTH
#define WM8903_GP1_DB
#define WM8903_GP1_DB_MASK
#define WM8903_GP1_DB_SHIFT
#define WM8903_GP1_DB_WIDTH

/*
 * R117 (0x75) - GPIO Control 2
 */
#define WM8903_GP2_FN_MASK
#define WM8903_GP2_FN_SHIFT
#define WM8903_GP2_FN_WIDTH
#define WM8903_GP2_DIR
#define WM8903_GP2_DIR_MASK
#define WM8903_GP2_DIR_SHIFT
#define WM8903_GP2_DIR_WIDTH
#define WM8903_GP2_OP_CFG
#define WM8903_GP2_OP_CFG_MASK
#define WM8903_GP2_OP_CFG_SHIFT
#define WM8903_GP2_OP_CFG_WIDTH
#define WM8903_GP2_IP_CFG
#define WM8903_GP2_IP_CFG_MASK
#define WM8903_GP2_IP_CFG_SHIFT
#define WM8903_GP2_IP_CFG_WIDTH
#define WM8903_GP2_LVL
#define WM8903_GP2_LVL_MASK
#define WM8903_GP2_LVL_SHIFT
#define WM8903_GP2_LVL_WIDTH
#define WM8903_GP2_PD
#define WM8903_GP2_PD_MASK
#define WM8903_GP2_PD_SHIFT
#define WM8903_GP2_PD_WIDTH
#define WM8903_GP2_PU
#define WM8903_GP2_PU_MASK
#define WM8903_GP2_PU_SHIFT
#define WM8903_GP2_PU_WIDTH
#define WM8903_GP2_INTMODE
#define WM8903_GP2_INTMODE_MASK
#define WM8903_GP2_INTMODE_SHIFT
#define WM8903_GP2_INTMODE_WIDTH
#define WM8903_GP2_DB
#define WM8903_GP2_DB_MASK
#define WM8903_GP2_DB_SHIFT
#define WM8903_GP2_DB_WIDTH

/*
 * R118 (0x76) - GPIO Control 3
 */
#define WM8903_GP3_FN_MASK
#define WM8903_GP3_FN_SHIFT
#define WM8903_GP3_FN_WIDTH
#define WM8903_GP3_DIR
#define WM8903_GP3_DIR_MASK
#define WM8903_GP3_DIR_SHIFT
#define WM8903_GP3_DIR_WIDTH
#define WM8903_GP3_OP_CFG
#define WM8903_GP3_OP_CFG_MASK
#define WM8903_GP3_OP_CFG_SHIFT
#define WM8903_GP3_OP_CFG_WIDTH
#define WM8903_GP3_IP_CFG
#define WM8903_GP3_IP_CFG_MASK
#define WM8903_GP3_IP_CFG_SHIFT
#define WM8903_GP3_IP_CFG_WIDTH
#define WM8903_GP3_LVL
#define WM8903_GP3_LVL_MASK
#define WM8903_GP3_LVL_SHIFT
#define WM8903_GP3_LVL_WIDTH
#define WM8903_GP3_PD
#define WM8903_GP3_PD_MASK
#define WM8903_GP3_PD_SHIFT
#define WM8903_GP3_PD_WIDTH
#define WM8903_GP3_PU
#define WM8903_GP3_PU_MASK
#define WM8903_GP3_PU_SHIFT
#define WM8903_GP3_PU_WIDTH
#define WM8903_GP3_INTMODE
#define WM8903_GP3_INTMODE_MASK
#define WM8903_GP3_INTMODE_SHIFT
#define WM8903_GP3_INTMODE_WIDTH
#define WM8903_GP3_DB
#define WM8903_GP3_DB_MASK
#define WM8903_GP3_DB_SHIFT
#define WM8903_GP3_DB_WIDTH

/*
 * R119 (0x77) - GPIO Control 4
 */
#define WM8903_GP4_FN_MASK
#define WM8903_GP4_FN_SHIFT
#define WM8903_GP4_FN_WIDTH
#define WM8903_GP4_DIR
#define WM8903_GP4_DIR_MASK
#define WM8903_GP4_DIR_SHIFT
#define WM8903_GP4_DIR_WIDTH
#define WM8903_GP4_OP_CFG
#define WM8903_GP4_OP_CFG_MASK
#define WM8903_GP4_OP_CFG_SHIFT
#define WM8903_GP4_OP_CFG_WIDTH
#define WM8903_GP4_IP_CFG
#define WM8903_GP4_IP_CFG_MASK
#define WM8903_GP4_IP_CFG_SHIFT
#define WM8903_GP4_IP_CFG_WIDTH
#define WM8903_GP4_LVL
#define WM8903_GP4_LVL_MASK
#define WM8903_GP4_LVL_SHIFT
#define WM8903_GP4_LVL_WIDTH
#define WM8903_GP4_PD
#define WM8903_GP4_PD_MASK
#define WM8903_GP4_PD_SHIFT
#define WM8903_GP4_PD_WIDTH
#define WM8903_GP4_PU
#define WM8903_GP4_PU_MASK
#define WM8903_GP4_PU_SHIFT
#define WM8903_GP4_PU_WIDTH
#define WM8903_GP4_INTMODE
#define WM8903_GP4_INTMODE_MASK
#define WM8903_GP4_INTMODE_SHIFT
#define WM8903_GP4_INTMODE_WIDTH
#define WM8903_GP4_DB
#define WM8903_GP4_DB_MASK
#define WM8903_GP4_DB_SHIFT
#define WM8903_GP4_DB_WIDTH

/*
 * R120 (0x78) - GPIO Control 5
 */
#define WM8903_GP5_FN_MASK
#define WM8903_GP5_FN_SHIFT
#define WM8903_GP5_FN_WIDTH
#define WM8903_GP5_DIR
#define WM8903_GP5_DIR_MASK
#define WM8903_GP5_DIR_SHIFT
#define WM8903_GP5_DIR_WIDTH
#define WM8903_GP5_OP_CFG
#define WM8903_GP5_OP_CFG_MASK
#define WM8903_GP5_OP_CFG_SHIFT
#define WM8903_GP5_OP_CFG_WIDTH
#define WM8903_GP5_IP_CFG
#define WM8903_GP5_IP_CFG_MASK
#define WM8903_GP5_IP_CFG_SHIFT
#define WM8903_GP5_IP_CFG_WIDTH
#define WM8903_GP5_LVL
#define WM8903_GP5_LVL_MASK
#define WM8903_GP5_LVL_SHIFT
#define WM8903_GP5_LVL_WIDTH
#define WM8903_GP5_PD
#define WM8903_GP5_PD_MASK
#define WM8903_GP5_PD_SHIFT
#define WM8903_GP5_PD_WIDTH
#define WM8903_GP5_PU
#define WM8903_GP5_PU_MASK
#define WM8903_GP5_PU_SHIFT
#define WM8903_GP5_PU_WIDTH
#define WM8903_GP5_INTMODE
#define WM8903_GP5_INTMODE_MASK
#define WM8903_GP5_INTMODE_SHIFT
#define WM8903_GP5_INTMODE_WIDTH
#define WM8903_GP5_DB
#define WM8903_GP5_DB_MASK
#define WM8903_GP5_DB_SHIFT
#define WM8903_GP5_DB_WIDTH

#define WM8903_NUM_GPIO

struct wm8903_platform_data {};

#endif