Skip to content
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 STM32C0/G0/L0 ADC driver #94

Open
wants to merge 12 commits into
base: master
Choose a base branch
from

Conversation

nandojve
Copy link

@nandojve nandojve commented Dec 29, 2023

This fixes all open issues that blocks the STM32 ADC to run in the C0/G0/L0 devices. The related issues are:

This was tested using Zephyr mainline using https://github.com/zephyrproject-rtos/zephyr/tree/main/samples/drivers/adc sample using the following branch https://github.com/nandojve/zephyr/tree/renode/fix_stm32_c0g0l0_adc.

Assuming the renode already in the path the below command allow build and run the simulation.

west build -b nucleo_g071rb deps/zephyr/samples/drivers/adc -t run
west build -b b_l072z_lrwan1 deps/zephyr/samples/drivers/adc -t run
west build -b nucleo_c031c6 deps/zephyr/samples/drivers/adc -t run

depends on antmicro/dts2repl#6 and antmicro/dts2repl#5

Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
The STM32_ADC_Common define the 0xC4 address for ADC_CALFACT register.
This is only valid for the most advanced version of adc peripheral
which is not compatible with the low cost devices like C0/G0/L0. This
add a selector at class instanciation to allow the correct definition
of the address.

Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
Add mising ADVREGEN tag bit from ADC_CR register.

Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
Rename EOSEQ to EOS in ADC_ISR register to be compliance with
C0/F0/G0/L0/WBA.

Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
The STM32L0 ADC still in a loop waiting the calibration phase
finish. This implement the calibration interrupt to finish
calibration procedure and allow ADC driver to work.

Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
The STM32G0 ADC still in a loop waiting the channel config be
ready. This implement the Channel Config Ready interrupt to
based on CHSELRMOD and SCANDIR changes to allow ADC driver to
work.

Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
Signed-off-by: Gerson Fernando Budke <gerson.budke@ossystems.com.br>
@otavio
Copy link

otavio commented Feb 28, 2024

Cc: @mateusz-holenko

@tyler-macinnis
Copy link

Is there anything in particular that is delaying this PR from being completed? It has been over 2 months.

@nandojve
Copy link
Author

nandojve commented Apr 30, 2024

Is there anything in particular that is delaying this PR from being completed? It has been over 2 months.

Hi @tyler-macinnis ,

We synced 2 weeks ago with Renode team and we are waiting decision about possible API changes. After that we may apply a few changes, if necessary, but I believe this will start to move forward soon.

@pgielda
Copy link
Member

pgielda commented May 6, 2024

Is there anything in particular that is delaying this PR from being completed? It has been over 2 months.

I am confused here... Its been two months since what? Can you elaborate on what company/project you represent? This whole discussion is weird. You all seem to be working on some project that I (nor anyone else in my company) am not aware of. We will reach out (over email) to @nandojve since we know each other from Zephyr Project so that there is a possibility to get additional context, but if the tone here and the pressure (passive aggressive complaints or CCing people) will not change then I will close just this PR...

@otavio
Copy link

otavio commented May 6, 2024

@pgielda, @nandojve, and I (@otavio) work for O.S. Systems. @tyler-macinnis is a community user who seems to be affected by the same issue that @nandojve and I resolved. We didn't want to appear impolite.

@tyler-macinnis
Copy link

I meant that it had been two months since this last message. I was just curious about the current state/progress of this PR since it will indeed resolve an issue I am affected by as well.

@pgielda
Copy link
Member

pgielda commented May 6, 2024

Well pinging a random person on github was never a way to achieve a result. @mateusz-holenko (nor anyone from the Renode team) has no clue who @otavio is... Opening a PR is enough, no need to ping us, especially specific random engineers... It will be looked at when its looked at...

@pgielda
Copy link
Member

pgielda commented May 6, 2024

Just so that its clear @tyler-macinnis, this is an external PR, so there is no timeline. None of the people in this discussion (apart from me) are from the Renode team.

But we do plan to address ADCs for more STM32 platforms at some point, but also tons of other things that are planned that might be more important... Unfortunately there is 10x more stuff to be done than time.

Having said that Renode does allow to load peripheral code in runtime so you can just download those and load them in runtime in your scripts. (just do "include @/path/to/file.cs" in your resc script and Renode will compile and load the code).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants