Commit a35daac7 authored by Lars-Peter Clausen's avatar Lars-Peter Clausen Committed by Mark Brown

ASoC: sigmadsp: Add support for fw v2

This patch adds support for the v2 version of the SigmaDSP firmware file
format. The new format has support for having different program and
parameter settings for different samplerates. In addition it stores metadata
describing the firmware. This metadata includes the set of supported
samplerates which will be used to restrict the samplerates that can be
selected by userspace. Also included is information about the modifiable
parameters. Those will be exposed as ALSA controls so they can be changed at
runtime.

The new format is based on a binary type-length-value structure that makes
it both forward and backwards compatible.
Signed-off-by: default avatarLars-Peter Clausen <lars@metafoo.de>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent d48b088e
...@@ -34,6 +34,34 @@ static int sigmadsp_write_i2c(void *control_data, ...@@ -34,6 +34,34 @@ static int sigmadsp_write_i2c(void *control_data,
return ret; return ret;
} }
static int sigmadsp_read_i2c(void *control_data,
unsigned int addr, uint8_t data[], size_t len)
{
struct i2c_client *client = control_data;
struct i2c_msg msgs[2];
uint8_t buf[2];
int ret;
put_unaligned_be16(addr, buf);
msgs[0].addr = client->addr;
msgs[0].len = sizeof(buf);
msgs[0].buf = buf;
msgs[0].flags = 0;
msgs[1].addr = client->addr;
msgs[1].len = len;
msgs[1].buf = data;
msgs[1].flags = I2C_M_RD;
ret = i2c_transfer(client->adapter, msgs, ARRAY_SIZE(msgs));
if (ret < 0)
return ret;
else if (ret != ARRAY_SIZE(msgs))
return -EIO;
return 0;
}
/** /**
* devm_sigmadsp_init_i2c() - Initialize SigmaDSP instance * devm_sigmadsp_init_i2c() - Initialize SigmaDSP instance
* @client: The parent I2C device * @client: The parent I2C device
...@@ -55,6 +83,7 @@ struct sigmadsp *devm_sigmadsp_init_i2c(struct i2c_client *client, ...@@ -55,6 +83,7 @@ struct sigmadsp *devm_sigmadsp_init_i2c(struct i2c_client *client,
sigmadsp->control_data = client; sigmadsp->control_data = client;
sigmadsp->write = sigmadsp_write_i2c; sigmadsp->write = sigmadsp_write_i2c;
sigmadsp->read = sigmadsp_read_i2c;
return sigmadsp; return sigmadsp;
} }
......
...@@ -19,6 +19,13 @@ static int sigmadsp_write_regmap(void *control_data, ...@@ -19,6 +19,13 @@ static int sigmadsp_write_regmap(void *control_data,
data, len); data, len);
} }
static int sigmadsp_read_regmap(void *control_data,
unsigned int addr, uint8_t data[], size_t len)
{
return regmap_raw_read(control_data, addr,
data, len);
}
/** /**
* devm_sigmadsp_init_i2c() - Initialize SigmaDSP instance * devm_sigmadsp_init_i2c() - Initialize SigmaDSP instance
* @dev: The parent device * @dev: The parent device
...@@ -42,6 +49,7 @@ struct sigmadsp *devm_sigmadsp_init_regmap(struct device *dev, ...@@ -42,6 +49,7 @@ struct sigmadsp *devm_sigmadsp_init_regmap(struct device *dev,
sigmadsp->control_data = regmap; sigmadsp->control_data = regmap;
sigmadsp->write = sigmadsp_write_regmap; sigmadsp->write = sigmadsp_write_regmap;
sigmadsp->read = sigmadsp_read_regmap;
return sigmadsp; return sigmadsp;
} }
......
This diff is collapsed.
...@@ -27,14 +27,20 @@ struct sigmadsp_ops { ...@@ -27,14 +27,20 @@ struct sigmadsp_ops {
struct sigmadsp { struct sigmadsp {
const struct sigmadsp_ops *ops; const struct sigmadsp_ops *ops;
struct list_head ctrl_list;
struct list_head data_list; struct list_head data_list;
struct snd_pcm_hw_constraint_list rate_constraints;
unsigned int current_samplerate; unsigned int current_samplerate;
struct snd_soc_component *component; struct snd_soc_component *component;
struct device *dev; struct device *dev;
struct mutex lock;
void *control_data; void *control_data;
int (*write)(void *, unsigned int, const uint8_t *, size_t); int (*write)(void *, unsigned int, const uint8_t *, size_t);
int (*read)(void *, unsigned int, uint8_t *, size_t);
}; };
struct sigmadsp *devm_sigmadsp_init(struct device *dev, struct sigmadsp *devm_sigmadsp_init(struct device *dev,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment