summaryrefslogtreecommitdiffstats
path: root/sound/soc/codecs/wm_adsp.h
diff options
context:
space:
mode:
authorSimon Trimmer <simont@opensource.cirrus.com>2021-09-13 18:00:55 +0200
committerMark Brown <broonie@kernel.org>2021-09-27 14:00:40 +0200
commite146820215910d889ab16d6c2484fd51a6bb8f1f (patch)
treeb3a042b96554494111561b3e8ba83c67a0fe3dfb /sound/soc/codecs/wm_adsp.h
parentASoC: wm_adsp: move firmware loading to client (diff)
downloadlinux-e146820215910d889ab16d6c2484fd51a6bb8f1f.tar.xz
linux-e146820215910d889ab16d6c2484fd51a6bb8f1f.zip
ASoC: wm_adsp: Split out struct cs_dsp from struct wm_adsp
In preparation for moving the generic DSP support out of ASoC split struct wm_adsp into two parts, one will form the structure for the new generic DSP code and embed that one into wm_adsp. Signed-off-by: Simon Trimmer <simont@opensource.cirrus.com> Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com> Link: https://lore.kernel.org/r/20210913160057.103842-15-simont@opensource.cirrus.com Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to '')
-rw-r--r--sound/soc/codecs/wm_adsp.h60
1 files changed, 32 insertions, 28 deletions
diff --git a/sound/soc/codecs/wm_adsp.h b/sound/soc/codecs/wm_adsp.h
index 3bad022c4bb1..5a70b6679fa3 100644
--- a/sound/soc/codecs/wm_adsp.h
+++ b/sound/soc/codecs/wm_adsp.h
@@ -49,7 +49,6 @@ struct cs_dsp_alg_region {
unsigned int base;
};
-struct wm_adsp;
struct wm_adsp_compr;
struct wm_adsp_compr_buf;
struct cs_dsp_ops;
@@ -60,7 +59,7 @@ struct cs_dsp_coeff_ctl {
const char *subname;
unsigned int subname_len;
struct cs_dsp_alg_region alg_region;
- struct wm_adsp *dsp;
+ struct cs_dsp *dsp;
unsigned int enabled:1;
struct list_head list;
void *cache;
@@ -73,16 +72,13 @@ struct cs_dsp_coeff_ctl {
void *priv;
};
-struct wm_adsp {
- const char *part;
+struct cs_dsp {
const char *name;
- const char *fwf_name;
int rev;
int num;
int type;
struct device *dev;
struct regmap *regmap;
- struct snd_soc_component *component;
const struct cs_dsp_ops *ops;
@@ -102,23 +98,13 @@ struct wm_adsp {
const struct cs_dsp_region *mem;
int num_mems;
- unsigned int sys_config_size;
-
- int fw;
int fw_ver;
- bool preloaded;
bool booted;
bool running;
- bool fatal_error;
struct list_head ctl_list;
- struct work_struct boot_work;
-
- struct list_head compr_list;
- struct list_head buffer_list;
-
struct mutex pwr_lock;
unsigned int lock_regions;
@@ -128,31 +114,49 @@ struct wm_adsp {
char *wmfw_file_name;
char *bin_file_name;
#endif
+};
+struct wm_adsp {
+ struct cs_dsp cs_dsp;
+ const char *part;
+ const char *fwf_name;
+ struct snd_soc_component *component;
+
+ unsigned int sys_config_size;
+
+ int fw;
+
+ struct work_struct boot_work;
+
+ bool preloaded;
+ bool fatal_error;
+
+ struct list_head compr_list;
+ struct list_head buffer_list;
};
struct cs_dsp_ops {
- bool (*validate_version)(struct wm_adsp *dsp, unsigned int version);
- unsigned int (*parse_sizes)(struct wm_adsp *dsp,
+ bool (*validate_version)(struct cs_dsp *dsp, unsigned int version);
+ unsigned int (*parse_sizes)(struct cs_dsp *dsp,
const char * const file,
unsigned int pos,
const struct firmware *firmware);
- int (*setup_algs)(struct wm_adsp *dsp);
+ int (*setup_algs)(struct cs_dsp *dsp);
unsigned int (*region_to_reg)(struct cs_dsp_region const *mem,
unsigned int offset);
- void (*show_fw_status)(struct wm_adsp *dsp);
- void (*stop_watchdog)(struct wm_adsp *dsp);
+ void (*show_fw_status)(struct cs_dsp *dsp);
+ void (*stop_watchdog)(struct cs_dsp *dsp);
- int (*enable_memory)(struct wm_adsp *dsp);
- void (*disable_memory)(struct wm_adsp *dsp);
- int (*lock_memory)(struct wm_adsp *dsp, unsigned int lock_regions);
+ int (*enable_memory)(struct cs_dsp *dsp);
+ void (*disable_memory)(struct cs_dsp *dsp);
+ int (*lock_memory)(struct cs_dsp *dsp, unsigned int lock_regions);
- int (*enable_core)(struct wm_adsp *dsp);
- void (*disable_core)(struct wm_adsp *dsp);
+ int (*enable_core)(struct cs_dsp *dsp);
+ void (*disable_core)(struct cs_dsp *dsp);
- int (*start_core)(struct wm_adsp *dsp);
- void (*stop_core)(struct wm_adsp *dsp);
+ int (*start_core)(struct cs_dsp *dsp);
+ void (*stop_core)(struct cs_dsp *dsp);
};
#define WM_ADSP1(wname, num) \