cancel
Showing results for 
Search instead for 
Did you mean: 

AzureRTOS (Threadx) USBPD support

Softronic Solutions
Associate III

Dear all,

I'm working on an custom hardware project using the STM32G0B1 MCU running ThreadX.  My goal is to use/port the USBPD stack for both source as sink device, but I'm failing to do so partly because the stack provided is closed source.

The CubeMX skeleton code generated for my project does not offer a working solution and all example code nor documentation available is not targeting ThreadX.

Also I'm somewhat confused about which PD stack to use since X-CUBE-USB-PD is no longer recommended? Then what would be the alternative stack to use?

Does anyone have practical experience, can provide meaningful documentation or example code porting USBPD to ThreadX? I would be forever thankful.

Thanks and looking forward to your replies.

With regards,

Peter

 

 

1 ACCEPTED SOLUTION

Accepted Solutions

Hi @Softronic Solutions 

Ticket 190248 is under investigation by CubeMX team. Workaround proposed is to manually add the function call MX_UCPD1_Init() in the initialization section of your code in case port configuration Port0:UCPD1 and Port1: UCPD2.

The example provided in Demo is very interesting. You can follow the implementation in STM32Cube\Repository\STM32Cube_FW_G0_V1.6.2\Projects\STM32G0C1E-EV\Demonstrations\Demo

To give better visibility on the answered topics, please click on Accept as Solution on the reply which solved your issue or answered your question.


View solution in original post

20 REPLIES 20
Nicolas P.
ST Employee

Hello Peter,

there are examples of USBPD applications using ThreadX, have a look here : STM32U5 on github.

Have a look at the Wiki. You will find all the available examples on all STM32.

And yes, the page  X-CUBE-USB-PD is no more supported. As it is explained on this page, this solution was to be used with a TCPC/TCPM architecture. But since the USB power delivery is natively supported by the latest STM32, no need to have an external PD controller.

The most updated stack is available here, with the x-cub-tcpp sw pack.

And now CubeMX can handle this pack. Have a look at this page for dual role support : DRP Wiki .

Hope it helps, tell me if you need more information.

Softronic Solutions
Associate III

Dear Nicolas,

Thank you for your reply.

First let me correct you, I'm not looking into a DRP but a separate SINK and a separate SOURCE implementation  each on a dedicated ucpd port.

Meanwhile I've been making some small successes but I'm still faced with issues/questions.

FYI I'm adding PD packet traces taken with a CC line bus sniffer.

SoftronicSolutions_0-1725287527478.png

First thing I noticed is that it takes the SINK ST USPD stack a long time before it start replying to the SOURCE (= well known Anker PD power adaptor), is there a known reason for that?  Keep in mind that the PD stack is fully initialised before I attach USB plug.

Second issue is that when I'm the stack is replying it's replying with a strange request for 0A current?

Could that be related to something that is (not) defined in usbpd_dpm_conf.h?

SoftronicSolutions_1-1725288210069.png

Because I find it strange that it defines external variables that are nowhere declared and the once that are declared from CubeMX are grayed/compiled out.

Hello Peter @Softronic Solutions ,

Good if you move forward.

To help you, it would be more than helpful if you could share your .cpd trace (see : Trace wiki). I hope you have an UART available for debug...

We would see the timings thanks to the timestamps traces, from the internal stack perspective.

There are also debug messages that would help telling if you have filled in correctly all the functions. (Look for "ADVICE" messages in the trace)

Perhaps you could also share your AzureRTOS tasks priorities order ?

Regards,

Nicolas

Hello Nicolas,

Well that was brutal!  As requested I enabled the TRACER_EMB

SoftronicSolutions_0-1725372707332.png

Enabled the GUI_INTERFACE

SoftronicSolutions_1-1725372791476.png

Recreated the skeleton code complied it without errors, but it completely ruined my application.

Nothing was working any more.  After some debugging I found that when enabling the TRACER_EMB the DMA interrupt section got overwritten entering the TRACER_EMB_IRQHandlerDMA() function but removing all other DMA handlers which basically the CubeMX (re-)adds without TRACE_EMB enabled.

SoftronicSolutions_2-1725373065677.png

To proceed I added them manually to make sure the remaining code remained working.

Now when running the code with the STM32CubeMonitor USB Type-C PD attached I get only this.

Each time I reboot the code the same entry appears, but nothing else is displayed not even when re-plugging the USB cable.

SoftronicSolutions_3-1725373309217.png

While my external CC-line tracer is able to capture this.

SoftronicSolutions_4-1725373508483.png

So much for the TRACER_EMB functionality, as I don't have much appetijt for spending time debugging the debugger here.

 

Softronic Solutions
Associate III

Dear Nicolas,

There is one topic that I needed to verify with you.

The instruction video's mention the use and configuration of X-CUBE-TCPP, while I'm not enabling it at all since it doesn't allow me to create one SINK and one SOURCE application.

SoftronicSolutions_5-1725374048340.png

And I'm also not using any of the X-nucleo boards or used parts either.

How does that affect the skeleton code created?

If you are not using the TCPPs, you should avoid using the CubeMX pack x-cube-tcpp...

One question : are you looping port 1 to port 2 ? Have you tried to generate and test one port only (source or sink) ?

Not using any of the TCPP's, thanks for confirming that topic.

I'm not looping any of the ports both ports need to be handled individual.

I'm focused on getting the SINK port working using an external USBPD charger adaptor, but the skeleton code is generated for both SINK and SOURCE.

SoftronicSolutions_0-1725381853558.png

SoftronicSolutions_2-1725381891698.png

SoftronicSolutions_3-1725382029260.png

Would it help if you can have a look at the project/code?

Nicolas P.
ST Employee

Yes, you can share your ioc.

But if the two ports are independent, it could be simpler to start first with sink port for example, and then source.

To avoid mixing multiple issues.

Hi Nicolas,

Sharing the projects IOC file here.

Would be good if you could return a working SINK example project based on this IOC that would allow me to continue build upon.

Meanwhile I'll try your suggestion of removing the SOURCE section from the project.