123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- #include <linux/regmap.h>
- #include <linux/device.h>
- #include <asoc/wcd9360-registers.h>
- #include "../core.h"
- #include "../wcd9xxx-regmap.h"
- #include "wcd9360-defaults.h"
- static bool wcd9360_is_readable_register(struct device *dev, unsigned int reg)
- {
- u8 pg_num, reg_offset;
- const u8 *reg_tbl = NULL;
-
- pg_num = reg >> 8;
- if (pg_num == 128)
- pg_num = WCD9360_PAGE_128;
- else if (pg_num == 80)
- pg_num = WCD9360_PAGE_80;
- else if (pg_num > 15)
- return false;
- reg_tbl = wcd9360_reg[pg_num];
- reg_offset = reg & 0xFF;
- if (reg_tbl && reg_tbl[reg_offset])
- return true;
- else
- return false;
- }
- static bool wcd9360_is_volatile_register(struct device *dev, unsigned int reg)
- {
- u8 pg_num, reg_offset;
- const u8 *reg_tbl = NULL;
- pg_num = reg >> 8;
- if (pg_num == 1 || pg_num == 2 ||
- pg_num == 6 || pg_num == 7)
- return true;
- else if (pg_num == 128)
- pg_num = WCD9360_PAGE_128;
- else if (pg_num == 80)
- pg_num = WCD9360_PAGE_80;
- else if (pg_num > 15)
- return false;
- reg_tbl = wcd9360_reg[pg_num];
- reg_offset = reg & 0xFF;
- if (reg_tbl && reg_tbl[reg_offset] == WCD9360_RO)
- return true;
- if ((reg >= WCD9360_CODEC_RPM_RST_CTL) &&
- (reg <= WCD9360_CHIP_TIER_CTRL_ALT_FUNC_EN))
- return true;
- if ((reg >= WCD9360_CDC_ANC0_IIR_COEFF_1_CTL) &&
- (reg <= WCD9360_CDC_ANC0_FB_GAIN_CTL))
- return true;
- if ((reg >= WCD9360_CODEC_CPR_WR_DATA_0) &&
- (reg <= WCD9360_CODEC_CPR_RD_DATA_3))
- return true;
-
- switch (reg) {
- case WCD9360_CODEC_RPM_CLK_BYPASS:
- case WCD9360_CODEC_RPM_CLK_GATE:
- case WCD9360_CODEC_RPM_CLK_MCLK_CFG:
- case WCD9360_CODEC_CPR_SVS_CX_VDD:
- case WCD9360_CODEC_CPR_SVS2_CX_VDD:
- case WCD9360_CDC_SIDETONE_IIR0_IIR_COEF_B1_CTL:
- case WCD9360_CDC_SIDETONE_IIR0_IIR_COEF_B2_CTL:
- return true;
- }
- return false;
- }
- struct regmap_config wcd9360_regmap_config = {
- .reg_bits = 16,
- .val_bits = 8,
- .cache_type = REGCACHE_RBTREE,
- .reg_defaults = wcd9360_defaults,
- .num_reg_defaults = ARRAY_SIZE(wcd9360_defaults),
- .max_register = WCD9360_MAX_REGISTER,
- .volatile_reg = wcd9360_is_volatile_register,
- .readable_reg = wcd9360_is_readable_register,
- .can_multi_write = true,
- };
|