1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * linux/sound/cs35l36.h -- Platform data for CS35L36 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright 2018 Cirrus Logic, Inc. 6*4882a593Smuzhiyun * 7*4882a593Smuzhiyun * Author: James Schulman <james.schulman@cirrus.com> 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun */ 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #ifndef __CS35L36_H 12*4882a593Smuzhiyun #define __CS35L36_H 13*4882a593Smuzhiyun 14*4882a593Smuzhiyun struct cs35l36_vpbr_cfg { 15*4882a593Smuzhiyun bool is_present; 16*4882a593Smuzhiyun bool vpbr_en; 17*4882a593Smuzhiyun int vpbr_thld; 18*4882a593Smuzhiyun int vpbr_atk_rate; 19*4882a593Smuzhiyun int vpbr_atk_vol; 20*4882a593Smuzhiyun int vpbr_max_attn; 21*4882a593Smuzhiyun int vpbr_wait; 22*4882a593Smuzhiyun int vpbr_rel_rate; 23*4882a593Smuzhiyun int vpbr_mute_en; 24*4882a593Smuzhiyun }; 25*4882a593Smuzhiyun 26*4882a593Smuzhiyun struct cs35l36_platform_data { 27*4882a593Smuzhiyun bool multi_amp_mode; 28*4882a593Smuzhiyun bool dcm_mode; 29*4882a593Smuzhiyun bool amp_pcm_inv; 30*4882a593Smuzhiyun bool imon_pol_inv; 31*4882a593Smuzhiyun bool vmon_pol_inv; 32*4882a593Smuzhiyun int boost_ind; 33*4882a593Smuzhiyun int bst_vctl; 34*4882a593Smuzhiyun int bst_vctl_sel; 35*4882a593Smuzhiyun int bst_ipk; 36*4882a593Smuzhiyun bool extern_boost; 37*4882a593Smuzhiyun int temp_warn_thld; 38*4882a593Smuzhiyun int irq_drv_sel; 39*4882a593Smuzhiyun int irq_gpio_sel; 40*4882a593Smuzhiyun struct cs35l36_vpbr_cfg vpbr_config; 41*4882a593Smuzhiyun }; 42*4882a593Smuzhiyun 43*4882a593Smuzhiyun #endif /* __CS35L36_H */ 44