^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0-only */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) * linux/sound/wm8996.h -- Platform data for WM8996
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) * Copyright 2011 Wolfson Microelectronics. PLC.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) #ifndef __LINUX_SND_WM8996_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) #define __LINUX_SND_WM8996_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) enum wm8996_inmode {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) WM8996_DIFFERRENTIAL_1 = 0, /* IN1xP - IN1xN */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) WM8996_INVERTING = 1, /* IN1xN */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) WM8996_NON_INVERTING = 2, /* IN1xP */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) WM8996_DIFFERENTIAL_2 = 3, /* IN2xP - IN2xP */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) /**
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) * ReTune Mobile configurations are specified with a label, sample
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) * rate and set of values to write (the enable bits will be ignored).
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) * Configurations are expected to be generated using the ReTune Mobile
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) * control panel in WISCE - see http://www.wolfsonmicro.com/wisce/
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) struct wm8996_retune_mobile_config {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) const char *name;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) int rate;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) u16 regs[20];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) #define WM8996_SET_DEFAULT 0x10000
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) struct wm8996_pdata {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) int irq_flags; /** Set IRQ trigger flags; default active low */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) int ldo_ena; /** GPIO for LDO1; -1 for none */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) int micdet_def; /** Default MICDET_SRC/HP1FB_SRC/MICD_BIAS */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) enum wm8996_inmode inl_mode;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) enum wm8996_inmode inr_mode;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) u32 spkmute_seq; /** Value for register 0x802 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) int gpio_base;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) u32 gpio_default[5];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) int num_retune_mobile_cfgs;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) struct wm8996_retune_mobile_config *retune_mobile_cfgs;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) #endif