Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 32 additions & 0 deletions boards/ti/am243x_evm/am243x_evm_am2434_r5f0_0-pinctrl.dtsi
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,38 @@
pinmux = <K3_PINMUX(0x264, PIN_INPUT_PULLUP, MUX_MODE_0)>;
};

main_adc0_ain0: adc0_ain0_default {
pinmux = <K3_PINMUX(0x2B0, PIN_INPUT, MUX_MODE_0)>;
};

main_adc0_ain1: adc0_ain1_default {
pinmux = <K3_PINMUX(0x2B4, PIN_INPUT, MUX_MODE_0)>;
};

main_adc0_ain2: adc0_ain2_default {
pinmux = <K3_PINMUX(0x2B8, PIN_INPUT, MUX_MODE_0)>;
};

main_adc0_ain3: adc0_ain3_default {
pinmux = <K3_PINMUX(0x2BC, PIN_INPUT, MUX_MODE_0)>;
};

main_adc0_ain4: adc0_ain4_default {
pinmux = <K3_PINMUX(0x2C0, PIN_INPUT, MUX_MODE_0)>;
};

main_adc0_ain5: adc0_ain5_default {
pinmux = <K3_PINMUX(0x2C4, PIN_INPUT, MUX_MODE_0)>;
};

main_adc0_ain6: adc0_ain6_default {
pinmux = <K3_PINMUX(0x2C8, PIN_INPUT, MUX_MODE_0)>;
};

main_adc0_ain7: adc0_ain7_default {
pinmux = <K3_PINMUX(0x2CC, PIN_INPUT, MUX_MODE_0)>;
};

spi0_cs0: spi0_cs0_default {
pinmux = <K3_PINMUX(0x208, PIN_OUTPUT, MUX_MODE_0)>;
};
Expand Down
85 changes: 3 additions & 82 deletions boards/ti/am243x_evm/am243x_evm_am2434_r5f0_0.dts
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@

aliases {
led0 = &ld26;
adc0 = &main_adc0;
};

leds: leds {
Expand Down Expand Up @@ -97,90 +96,12 @@
};

&main_adc0 {
ti,vrefp = <1800>;
ti,fifo = <0>;
pinctrl-0 = <&main_adc0_ain0 &main_adc0_ain1 &main_adc0_ain2 &main_adc0_ain3
&main_adc0_ain4 &main_adc0_ain5 &main_adc0_ain6 &main_adc0_ain7>;
pinctrl-names = "default";
status = "okay";
power-domains = <&adc0_pd>;

channel@0 {
reg = <0>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_INTERNAL";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
};

channel@1 {
reg = <1>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_INTERNAL";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
};

channel@2 {
reg = <2>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_INTERNAL";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
};

channel@3 {
reg = <3>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_INTERNAL";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
};

channel@4 {
reg = <4>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_INTERNAL";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
};

channel@5 {
reg = <5>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_INTERNAL";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
};

channel@6 {
reg = <6>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_INTERNAL";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
};

channel@7 {
reg = <7>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_INTERNAL";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
};
};

&main_mbox6 {
Expand Down
36 changes: 28 additions & 8 deletions drivers/adc/adc_ti_am335x.c
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
#include <zephyr/device.h>
#include <zephyr/kernel.h>
#include <zephyr/drivers/adc.h>
#include <zephyr/drivers/pinctrl.h>

#define ADC_CONTEXT_USES_KERNEL_TIMER
#include "adc_context.h"
Expand Down Expand Up @@ -97,6 +98,7 @@

struct ti_adc_cfg {
DEVICE_MMIO_ROM;
const struct pinctrl_dev_config *pinctrl;
void (*irq_func)(const struct device *dev);
uint32_t open_delay[TI_ADC_TOTAL_CHANNELS];
uint8_t oversampling[TI_ADC_TOTAL_CHANNELS];
Expand All @@ -122,7 +124,7 @@

static void adc_context_start_sampling(struct adc_context *ctx)
{
struct ti_adc_data *data = CONTAINER_OF(ctx, struct ti_adc_data, ctx);

Check warning on line 127 in drivers/adc/adc_ti_am335x.c

View check run for this annotation

SonarQubeCloud / SonarCloud Code Analysis

use of GNU statement expression extension from macro expansion

See more on https://sonarcloud.io/project/issues?id=zephyrproject-rtos_zephyr&issues=AZrp3jqlEVJzd5og3L48&open=AZrp3jqlEVJzd5og3L48&pullRequest=92170
struct ti_adc_regs *regs = DEV_REGS(data->dev);

regs->CONTROL &= ~TI_ADC_CONTROL_ENABLE;
Expand All @@ -141,7 +143,7 @@

static void adc_context_update_buffer_pointer(struct adc_context *ctx, bool repeat)
{
struct ti_adc_data *data = CONTAINER_OF(ctx, struct ti_adc_data, ctx);

Check warning on line 146 in drivers/adc/adc_ti_am335x.c

View check run for this annotation

SonarQubeCloud / SonarCloud Code Analysis

use of GNU statement expression extension from macro expansion

See more on https://sonarcloud.io/project/issues?id=zephyrproject-rtos_zephyr&issues=AZrp3jqlEVJzd5og3L49&open=AZrp3jqlEVJzd5og3L49&pullRequest=92170

if (repeat) {
data->buffer = data->repeat_buffer;
Expand Down Expand Up @@ -186,6 +188,11 @@
return -EINVAL;
}

if (chan_cfg->reference != ADC_REF_VDD_1) {
LOG_ERR("Invalid channel reference");
return -EINVAL;
}

if (chan_cfg->gain != ADC_GAIN_1) {
LOG_ERR("Gain must be 1x");
return -EINVAL;
Expand Down Expand Up @@ -288,10 +295,19 @@
{
const struct ti_adc_cfg *cfg = DEV_CFG(dev);
struct ti_adc_data *data = DEV_DATA(dev);
struct ti_adc_regs *regs = DEV_REGS(dev);
struct ti_adc_regs *regs;
int ret;

DEVICE_MMIO_MAP(dev, K_MEM_CACHE_NONE);

regs = DEV_REGS(dev);

ret = pinctrl_apply_state(cfg->pinctrl, PINCTRL_STATE_DEFAULT);
if (ret < 0) {
LOG_ERR("failed to apply pinctrl");
return ret;
}

cfg->irq_func(dev);

if (cfg->fifo == 0) {
Expand Down Expand Up @@ -370,13 +386,16 @@

#define CHAN_PROP_LIST(n, prop) {DT_INST_FOREACH_CHILD_SEP_VARGS(n, EXPLICIT_CHAN_PROP, (,), prop)}

static DEVICE_API(adc, ti_adc_driver_api) = {
.channel_setup = ti_adc_channel_setup,
.read = ti_adc_read,
#ifdef CONFIG_ADC_ASYNC
.read_async = ti_adc_read_async,
#endif /* CONFIG_ADC_ASYNC */
};

#define TI_ADC_INIT(n) \
static DEVICE_API(adc, ti_adc_driver_api_##n) = { \
.channel_setup = ti_adc_channel_setup, \
.read = ti_adc_read, \
.ref_internal = DT_INST_PROP(n, ti_vrefp), \
IF_ENABLED(CONFIG_ADC_ASYNC, (.read_async = ti_adc_read_async,)) }; \
\
PINCTRL_DT_INST_DEFINE(n); \
static void ti_adc_irq_setup_##n(const struct device *dev) \
{ \
IRQ_CONNECT(DT_INST_IRQN(n), DT_INST_IRQ(n, priority), ti_adc_isr, \
Expand All @@ -386,6 +405,7 @@
\
static const struct ti_adc_cfg ti_adc_cfg_##n = { \
DEVICE_MMIO_ROM_INIT(DT_DRV_INST(n)), \
.pinctrl = PINCTRL_DT_INST_DEV_CONFIG_GET(n), \
.irq_func = &ti_adc_irq_setup_##n, \
.open_delay = CHAN_PROP_LIST(n, ti_open_delay), \
.oversampling = CHAN_PROP_LIST(n, zephyr_oversampling), \
Expand All @@ -400,6 +420,6 @@
}; \
\
DEVICE_DT_INST_DEFINE(n, ti_adc_init, NULL, &ti_adc_data_##n, &ti_adc_cfg_##n, \
POST_KERNEL, CONFIG_ADC_INIT_PRIORITY, &ti_adc_driver_api_##n);
POST_KERNEL, CONFIG_ADC_INIT_PRIORITY, &ti_adc_driver_api);

DT_INST_FOREACH_STATUS_OKAY(TI_ADC_INIT)
7 changes: 1 addition & 6 deletions dts/bindings/adc/ti,am335x-adc.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,17 +6,12 @@ description: TI AM335X ADC

compatible: "ti,am335x-adc"

include: [adc-controller.yaml]
include: [adc-controller.yaml, pinctrl-device.yaml]

properties:
interrupts:
required: true

ti,vrefp:
type: int
required: true
description: Reference Voltage (in mV)

ti,fifo:
type: int
required: true
Expand Down
27 changes: 25 additions & 2 deletions samples/drivers/adc/adc_dt/boards/am243x_evm_am2434_r5f0_0.overlay
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,30 @@

/ {
zephyr,user {
io-channels = <&adc0 0>, <&adc0 1>, <&adc0 2>, <&adc0 3>, <&adc0 4>, <&adc0 5>,
<&adc0 6>, <&adc0 7>;
io-channels = <&main_adc0 0>, <&main_adc0 7>;
};
};

&main_adc0 {
channel@0 {
reg = <0>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_VDD_1";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
zephyr,vref-mv = <1800>;
};

channel@7 {
reg = <7>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_VDD_1";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
zephyr,vref-mv = <1800>;
};
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
/*
* Copyright (c) 2025 Texas Instruments
*
* SPDX-License-Identifier: Apache-2.0
*/

/ {
aliases {
adc0 = &main_adc0;
};
};

&main_adc0 {
channel@0 {
reg = <0>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_VDD_1";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
zephyr,vref-mv = <1800>;
};

channel@1 {
reg = <1>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_VDD_1";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
zephyr,vref-mv = <1800>;
};

channel@2 {
reg = <2>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_VDD_1";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
zephyr,vref-mv = <1800>;
};

channel@3 {
reg = <3>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_VDD_1";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
zephyr,vref-mv = <1800>;
};

channel@4 {
reg = <4>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_VDD_1";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
zephyr,vref-mv = <1800>;
};

channel@5 {
reg = <5>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_VDD_1";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
zephyr,vref-mv = <1800>;
};

channel@6 {
reg = <6>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_VDD_1";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
zephyr,vref-mv = <1800>;
};

channel@7 {
reg = <7>;
ti,open-delay = <0>;
zephyr,gain = "ADC_GAIN_1";
zephyr,reference = "ADC_REF_VDD_1";
zephyr,acquisition-time = <0>;
zephyr,resolution = <12>;
zephyr,oversampling = <4>;
zephyr,vref-mv = <1800>;
};
};