-
Notifications
You must be signed in to change notification settings - Fork 854
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for AD4052 ADC Family #2642
base: main
Are you sure you want to change the base?
Conversation
ce15fe8
to
86e6d7c
Compare
Forced pushed to:
Forced pushed (2) to:
Forced pushed (3) to:
|
1f5b827
to
9611c42
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here it goes first round of review...
I think this one can be upstreamed without the offload bits
4b81da9
to
494d89f
Compare
Change log v0 -> v1 Review changes:
New:
Design changes:
|
drivers/iio/adc/Kconfig
Outdated
tristate "Analog Devices AD4052 Driver" | ||
depends on SPI | ||
depends on PWM | ||
depends on GPIOLIB |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm also not sure if gpio is something you should depend on or just select it. I think the single shot reading could be something useful to have even more to make this driver more upstreamable without offload support (we can still some questions about it though).
drivers/iio/adc/Kconfig
Outdated
tristate "Analog Devices AD4052 Driver" | ||
depends on SPI | ||
depends on PWM | ||
depends on GPIOLIB |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also one not on the commit message. Style is iio: adc: ...
. Drop the drivers:
if (val == 0) { | ||
st->mode = AD4052_SAMPLE_MODE; | ||
} else { | ||
st->mode = AD4052_BURST_AVERAGING_MODE; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would double check other examples of oversampling. To me this is a 1 or 0 thing. Either it's enabled it not. Your mode variable also just seems to have two states here so the way you're handling val
raises some questions.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The device supports from 2 to 4096 in powers of 2 samples for avg mode.
Decided to reserve 0 and 1 to disable the feature (return to sample mode)
494d89f
to
03cfbc9
Compare
Change log v1 -> v2 Review changes:
Changes:
Extra force push to resolve merge conflict |
03cfbc9
to
a7eca14
Compare
eb23140
to
0506d4c
Compare
Change log v2 -> v3
|
0506d4c
to
b6ab861
Compare
This is not forgotten... I'll try to check it Monday |
b6ab861
to
4b0f9d7
Compare
Force pushed to resolve merge conflicts due to main rebase. |
4b0f9d7
to
204d667
Compare
@nunojsa is this version good enough to consider finished? |
Sorry for the slow approach on this one...
Definitely... But I would even say to maybe wait a few more weeks. We can be close to land spi offload support upstream.
I'll take a look. Note that CI is failing - maybe due to conflicts with 6.6 merge |
conv_state.period = DIV_ROUND_CLOSEST(NSEC_PER_SEC, freq); | ||
ret = pwm_apply_state(st->cnv_pwm, &conv_state); | ||
if (ret) | ||
return ret; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
#2640 will likely land first so you'll eventually need to adapt to the new API
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hum hum, rebased on that at https://github.com/analogdevicesinc/linux/tree/staging/ad4052-pwm
V3 -- ad4052-pwm diff:
git range-diff 6948bd2e357d4a316ac0af804a1e7c2bb3165101~..10a85eb73314419f7a5836ae064f51fa097f6101 752ba29b6c6a~..8c423d9fe643
Tested on HW with fsclk 31.2MHz
static IIO_DEVICE_ATTR(sampling_frequency, 0644, | ||
ad4052_buffer_sampling_freq_show, | ||
ad4052_buffer_sampling_freq_store, | ||
0); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why not typically read_raw/write_raw approach?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The IIO_CHAN_INFO_SAMP_FREQ is used for the ADC internal sampling frequency, which resolves to
/sys/bus/iio/devices/iio:device0/sampling_frequency
This one is attached to
/sys/bus/iio/devices/iio:device0/buffer/sampling_frequency
I'll look into this again (for V4?)
drivers/iio/adc/ad4052.c
Outdated
/* Single sample read should be used only for oversampling and | ||
* sampling frequency pairs that take less than 1 sec. | ||
*/ | ||
if (st->gp1_irq.enabled) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we do raw reads without the IRQ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Without oversampling enabled the raw read may be slower than the gpio CNV to spi transfer,
allowing to do raw reads without the IRQ.
But I will remove this option/use case.
Note: CNV and GP0 (threshold) are still optional.
Note 2: Since CNV is optional, if cnv not present I will yield an empty spi transfer to trigger a conversion (considering the user had shorten CNV to CS)
return PTR_ERR(gpio); | ||
|
||
if (gpio) { | ||
irq = gpiod_to_irq(gpio); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Directly use devm_request_threaded_irq()... i see one the IRQs is for completion but what's the purpose of the other one? We need some comments here I guess
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One is for the threshold IIO event (ad4052_irq_handler_thresh).
The other is drdy for raw read (completion).
I didn't get the comment to directly use devm_request_threaded_irq.
Do you want me to change from a soft interrupt from the GPIO (like ad9081,c) to a hard interrupt (like ad7280a.c)?
} else { | ||
val = ilog2(val); | ||
st->mode = AD4052_BURST_AVERAGING_MODE; | ||
ret = regmap_write(st->regmap, AD4052_REG_AVG_CONFIG, val - 1); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should still make sure val is valid right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It already bounds the value at AD4052_CHECK_OVERSAMPLING.
Add dt-bindings for AD4052 family, devices AD4050/AD4052/AD4056/AD4058, low-power with monitor capabilities SAR ADCs. Contain selectable oversampling and sample rate, the latter for both oversampling and monitor mode. The monitor capability is exposed as an IIO threshold either direction event. Signed-off-by: Jorge Marques <jorge.marques@analog.com>
The AD4052 CNV pin is driven by a GPIO for single shot readings and by a PWM for buffer readings. The functional-mode entry allows to set Sample Mode (0) or Burst Averaging Mode (1). During runtime, it is possible to enter Trigger Mode through IIO Events. Signed-off-by: Jorge Marques <jorge.marques@analog.com>
The AD4052/AD4058/AD4050/AD4056 are versatile, 16-bit/12-bit, successive approximation register (SAR) analog-to-digital converter (ADC) that enables low-power, high-density data acquisition solutions without sacrificing precision. This ADC offers a unique balance of performance and power efficiency, plus innovative features for seamlessly switching between high-resolution and low-power modes tailored to the immediate needs of the system. The AD4052/AD4058/AD4050/AD4056 are ideal for battery-powered, compact data acquisition and edge sensing applications. Signed-off-by: Jorge Marques <jorge.marques@analog.com>
Add entry for the AD4052 ADC family driver. Signed-off-by: Jorge Marques <jorge.marques@analog.com>
204d667
to
10a85eb
Compare
V2 -> V3
Tested on HW at fsclk 31.25MHz (could not achieve datasheet 62.5MHz). TODO: Solve buffer/sample_freq hack . Wait upstream offload? |
PR Description
Add:
Optional:
Features:
Overall, the highlight of this device is the monitor capability, leveraged by the autonomous trigger mode and exposed as IIO Event.
Linux driver doc:
HDL: analogdevicesinc/hdl#1504
Datasheet: www.analog.com/ad4052
Tested on Coraz7s
PR Type
PR Checklist