提交 2b6d598b 编写于 作者: J Josh Wu 提交者: Jonathan Cameron

iio: at91: move the num_channels from DT to driver itself

CC: devicetree@vger.kernel.org
Signed-off-by: NJosh Wu <josh.wu@atmel.com>
Acked-by: NLudovic Desroches <ludovic.desroches@atmel.com>
Signed-off-by: NJonathan Cameron <jic23@kernel.org>
上级 c4601666
...@@ -7,7 +7,6 @@ Required properties: ...@@ -7,7 +7,6 @@ Required properties:
- interrupts: Should contain the IRQ line for the ADC - interrupts: Should contain the IRQ line for the ADC
- atmel,adc-channels-used: Bitmask of the channels muxed and enable for this - atmel,adc-channels-used: Bitmask of the channels muxed and enable for this
device device
- atmel,adc-num-channels: Number of channels available in the ADC
- atmel,adc-startup-time: Startup Time of the ADC in microseconds as - atmel,adc-startup-time: Startup Time of the ADC in microseconds as
defined in the datasheet defined in the datasheet
- atmel,adc-vref: Reference voltage in millivolts for the conversions - atmel,adc-vref: Reference voltage in millivolts for the conversions
......
...@@ -43,6 +43,7 @@ struct at91_adc_caps { ...@@ -43,6 +43,7 @@ struct at91_adc_caps {
/* startup time calculate function */ /* startup time calculate function */
u32 (*calc_startup_ticks)(u8 startup_time, u32 adc_clk_khz); u32 (*calc_startup_ticks)(u8 startup_time, u32 adc_clk_khz);
u8 num_channels;
struct at91_adc_reg_desc registers; struct at91_adc_reg_desc registers;
}; };
...@@ -496,13 +497,6 @@ static int at91_adc_probe_dt(struct at91_adc_state *st, ...@@ -496,13 +497,6 @@ static int at91_adc_probe_dt(struct at91_adc_state *st,
} }
st->channels_mask = prop; st->channels_mask = prop;
if (of_property_read_u32(node, "atmel,adc-num-channels", &prop)) {
dev_err(&idev->dev, "Missing adc-num-channels property in the DT.\n");
ret = -EINVAL;
goto error_ret;
}
st->num_channels = prop;
st->sleep_mode = of_property_read_bool(node, "atmel,adc-sleep-mode"); st->sleep_mode = of_property_read_bool(node, "atmel,adc-sleep-mode");
if (of_property_read_u32(node, "atmel,adc-startup-time", &prop)) { if (of_property_read_u32(node, "atmel,adc-startup-time", &prop)) {
...@@ -528,6 +522,7 @@ static int at91_adc_probe_dt(struct at91_adc_state *st, ...@@ -528,6 +522,7 @@ static int at91_adc_probe_dt(struct at91_adc_state *st,
goto error_ret; goto error_ret;
st->registers = &st->caps->registers; st->registers = &st->caps->registers;
st->num_channels = st->caps->num_channels;
st->trigger_number = of_get_child_count(node); st->trigger_number = of_get_child_count(node);
st->trigger_list = devm_kzalloc(&idev->dev, st->trigger_number * st->trigger_list = devm_kzalloc(&idev->dev, st->trigger_number *
sizeof(struct at91_adc_trigger), sizeof(struct at91_adc_trigger),
...@@ -773,6 +768,7 @@ static int at91_adc_remove(struct platform_device *pdev) ...@@ -773,6 +768,7 @@ static int at91_adc_remove(struct platform_device *pdev)
#ifdef CONFIG_OF #ifdef CONFIG_OF
static struct at91_adc_caps at91sam9260_caps = { static struct at91_adc_caps at91sam9260_caps = {
.calc_startup_ticks = calc_startup_ticks_9260, .calc_startup_ticks = calc_startup_ticks_9260,
.num_channels = 4,
.registers = { .registers = {
.channel_base = AT91_ADC_CHR(0), .channel_base = AT91_ADC_CHR(0),
.drdy_mask = AT91_ADC_DRDY, .drdy_mask = AT91_ADC_DRDY,
...@@ -785,6 +781,7 @@ static struct at91_adc_caps at91sam9260_caps = { ...@@ -785,6 +781,7 @@ static struct at91_adc_caps at91sam9260_caps = {
static struct at91_adc_caps at91sam9g45_caps = { static struct at91_adc_caps at91sam9g45_caps = {
.calc_startup_ticks = calc_startup_ticks_9260, /* same as 9260 */ .calc_startup_ticks = calc_startup_ticks_9260, /* same as 9260 */
.num_channels = 8,
.registers = { .registers = {
.channel_base = AT91_ADC_CHR(0), .channel_base = AT91_ADC_CHR(0),
.drdy_mask = AT91_ADC_DRDY, .drdy_mask = AT91_ADC_DRDY,
...@@ -797,6 +794,7 @@ static struct at91_adc_caps at91sam9g45_caps = { ...@@ -797,6 +794,7 @@ static struct at91_adc_caps at91sam9g45_caps = {
static struct at91_adc_caps at91sam9x5_caps = { static struct at91_adc_caps at91sam9x5_caps = {
.calc_startup_ticks = calc_startup_ticks_9x5, .calc_startup_ticks = calc_startup_ticks_9x5,
.num_channels = 12,
.registers = { .registers = {
.channel_base = AT91_ADC_CDR0_9X5, .channel_base = AT91_ADC_CDR0_9X5,
.drdy_mask = AT91_ADC_SR_DRDY_9X5, .drdy_mask = AT91_ADC_SR_DRDY_9X5,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册