// SPDX-License-Identifier: GPL-2.0-only
//
// ALSA SoC Audio driver for CS47L15 codec
//
// Copyright (C) 2016-2019 Cirrus Logic, Inc. and
// Cirrus Logic International Semiconductor Ltd.
//
#include <linux/module.h>
#include <linux/moduleparam.h>
#include <linux/device.h>
#include <linux/delay.h>
#include <linux/init.h>
#include <linux/pm.h>
#include <linux/pm_runtime.h>
#include <linux/regmap.h>
#include <sound/core.h>
#include <sound/pcm.h>
#include <sound/pcm_params.h>
#include <sound/soc.h>
#include <sound/tlv.h>
#include <linux/irqchip/irq-madera.h>
#include <linux/mfd/madera/core.h>
#include <linux/mfd/madera/registers.h>
#include "madera.h"
#include "wm_adsp.h"
#define CS47L15_NUM_ADSP 1
#define CS47L15_MONO_OUTPUTS 1
/* Mid-mode registers */
#define CS47L15_ADC_INT_BIAS_MASK 0x3800
#define CS47L15_ADC_INT_BIAS_SHIFT 11
#define CS47L15_PGA_BIAS_SEL_MASK 0x03
#define CS47L15_PGA_BIAS_SEL_SHIFT 0
#define DRV_NAME "cs47l15-codec"
struct cs47l15 {
struct madera_priv core;
struct madera_fll fll[2];
bool in1_lp_mode;
};
static const struct cs_dsp_region cs47l15_dsp1_regions[] = {
{ .type = WMFW_ADSP2_PM, .base = 0x080000 },
{ .type =