Azure ThreadX

cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 

Azure ThreadX

Jump to solution
2,466 Views
DaveTonyCook
Contributor IV

Hi

The ThreadX demo in LPCXpresso SDK is missing Tx_initialize_low_level.S. It has been replaced by Tx_initialize_low_level.c which accesses the CMSIS interface, I assume to achieve the same thing. 

I have a ThreadX 5.0 project targeted at the Kinetis family that needs porting to the LPC55x. This uses the Tx_initialize_low_level.S to set up the managed interrupts.

My question is, how do you use Tx_initialize_low_level.c in place of my Tx_initialize_low_level.S to achieve the same thing. I can’t find any documentation to help guide me.

Thanks

Dave C

0 Kudos
1 Solution
2,429 Views
DaveTonyCook
Contributor IV

How about you don't delete the readme file associated with the GIT Hub download! Thanks for your useless comment!

We are porting an existing project based on ThreadX 5.0 which uses tx_initialize_low_level.s... debugging the tx_initialize_low_level.c would not provide the information I need to make a discussion regarding risk and timescale before we start the project nor would it answer the question regarding ThreadX managed interrupts.

I found that if you download Azure ThreadX from GIT hub the tx_initialize_low_level.s file is present along with a very helpful readme file, readme_threadx.txt which explains how to deal with Managed Interrupts.

It states that ISRs for Cortex-M using the IAR tools can be written completely in C, as your demo code has been, (or assembly language) without any calls to _tx_thread_context_save or _tx_thread_context_restore. These ISRs are allowed access to the ThreadX API that is available to ISRs. This answers my original question.

If I could give some feedback:

  • It would help if the readme_threadx.txt file is kept with both the demo code and the Azure ThreadX RTOS installation.
  • Update the Azure ThreadX in the SDK or advice users to download latest from GIT Hub as Microsoft do. The O/S component of the SDK for the LPC55x (M33) is not the latest at V6.1.8. The latest from GIT Hub is V6.1.11.

I have attached the readme file for your information please refer to sec 6.1 Managed Interrupts. I hope this helps you help others with further enquiries on this topic. For the help you have provided, thank you.

 

Microsoft's Azure RTOS ThreadX for Cortex-M33

Using the IAR Tools


1. Building the ThreadX run-time Library

Import all ThreadX common and port-specific source files into an IAR project.
Configure the project to build a library rather than an executable. This
results in the ThreadX run-time library file tx.a, which is needed by
the application.
Files tx_thread_stack_error_handler.c and tx_thread_stack_error_notify.c
replace the common files of the same name.

2. Demonstration System

No demonstration is provided because the IAR EWARM 8.50 simulator does
not simulate the Cortex-M33 correctly.


3. System Initialization

The entry point in ThreadX for the Cortex-M33 using IAR tools is at label
__iar_program_start. This is defined within the IAR compiler's startup code.
In addition, this is where all static and global preset C variable
initialization processing takes place.

The ThreadX tx_initialize_low_level.s file is responsible for setting up
various system data structures, and a periodic timer interrupt source.

The _tx_initialize_low_level function inside of tx_initialize_low_level.s
also determines the first available address for use by the application, which
is supplied as the sole input parameter to your application definition function,
tx_application_define. To accomplish this, a section is created in
tx_initialize_low_level.s called FREE_MEM, which must be located after all
other RAM sections in memory.


4. Register Usage and Stack Frames

The following defines the saved context stack frames for context switches
that occur as a result of interrupt handling or from thread-level API calls.
All suspended threads have the same stack frame in the Cortex-M33 version of
ThreadX. The top of the suspended thread's stack is pointed to by
tx_thread_stack_ptr in the associated thread control block TX_THREAD.

Non-FPU Stack Frame:

Stack Offset Stack Contents

0x00 LR Interrupted LR (LR at time of PENDSV)
0x04 r4 Software stacked GP registers
0x08 r5
0x0C r6
0x10 r7
0x14 r8
0x18 r9
0x1C r10
0x20 r11
0x24 r0 Hardware stacked registers
0x28 r1
0x2C r2
0x30 r3
0x34 r12
0x38 lr
0x3C pc
0x40 xPSR

FPU Stack Frame (only interrupted thread with FPU enabled):

Stack Offset Stack Contents

0x00 LR Interrupted LR (LR at time of PENDSV)
0x04 s16 Software stacked FPU registers
0x08 s17
0x0C s18
0x10 s19
0x14 s20
0x18 s21
0x1C s22
0x20 s23
0x24 s24
0x28 s25
0x2C s26
0x30 s27
0x34 s28
0x38 s29
0x3C s30
0x40 s31
0x44 r4 Software stacked registers
0x48 r5
0x4C r6
0x50 r7
0x54 r8
0x58 r9
0x5C r10
0x60 r11
0x64 r0 Hardware stacked registers
0x68 r1
0x6C r2
0x70 r3
0x74 r12
0x78 lr
0x7C pc
0x80 xPSR
0x84 s0 Hardware stacked FPU registers
0x88 s1
0x8C s2
0x90 s3
0x94 s4
0x98 s5
0x9C s6
0xA0 s7
0xA4 s8
0xA8 s9
0xAC s10
0xB0 s11
0xB4 s12
0xB8 s13
0xBC s14
0xC0 s15
0xC4 fpscr


5. Improving Performance

To make ThreadX and the application(s) run faster, you can enable
all compiler optimizations.

In addition, you can eliminate the ThreadX basic API error checking by
compiling your application code with the symbol TX_DISABLE_ERROR_CHECKING
defined.


6. Interrupt Handling

The Cortex-M33 vectors start at the label __vector_table and is typically defined in a
startup.s file (or similar). The application may modify the vector area according to its needs.


6.1 Managed Interrupts

ISRs for Cortex-M using the IAR tools can be written completely in C (or assembly
language) without any calls to _tx_thread_context_save or _tx_thread_context_restore.
These ISRs are allowed access to the ThreadX API that is available to ISRs.

ISRs written in C will take the form (where "your_C_isr" is an entry in the vector table):

void your_C_isr(void)
{

/* ISR processing goes here, including any needed function calls. */
}

ISRs written in assembly language will take the form:

PUBLIC your_assembly_isr
your_assembly_isr:

PUSH {r0, lr}

; ISR processing goes here, including any needed function calls.

POP {r0, lr}
BX lr


7. IAR Thread-safe Library Support

Thread-safe support for the IAR tools is easily enabled by building the ThreadX library
and the application with TX_ENABLE_IAR_LIBRARY_SUPPORT. Also, the linker control file
should have the following line added (if not already in place):

initialize by copy with packing = none { section __DLIB_PERTHREAD }; // Required in a multi-threaded application


7. IAR Thread-safe Library Support

Thread-safe support for the IAR tools is easily enabled by building the ThreadX library
and the application with TX_ENABLE_IAR_LIBRARY_SUPPORT. Also, the linker control file
should have the following line added (if not already in place):

initialize by copy with packing = none { section __DLIB_PERTHREAD }; // Required in a multi-threaded application

The project options "General Options -> Library Configuration" should also have the
"Enable thread support in library" box selected.


8. VFP Support

ThreadX for Cortex-M33 supports automatic ("lazy") VFP support, which means that applications threads
can simply use the VFP and ThreadX automatically maintains the VFP registers as part of the thread
context.


9. Revision History

For generic code revision information, please refer to the readme_threadx_generic.txt
file, which is included in your distribution. The following details the revision
information associated with this specific port of ThreadX:

06-02-2021 Release 6.1.7 changes:
tx_thread_secure_stack_initialize.s New file
tx_thread_schedule.s Added secure stack initialize to SVC hander
tx_thread_secure_stack.c Fixed stack pointer save, initialize in handler mode

04-02-2021 Release 6.1.6 changes:
tx_port.h Updated macro definition
tx_thread_schedule.s Added low power support

03-02-2021 The following files were changed/added for version 6.1.5:
tx_port.h Added ULONG64_DEFINED

09-30-2020 Initial ThreadX 6.1 version for Cortex-M33 using IAR's ARM tools.


Copyright(c) 1996-2020 Microsoft Corporation


https://azure.com/rtos

 

View solution in original post

0 Kudos
2 Replies
2,441 Views
Alice_Yang
NXP TechSupport
NXP TechSupport

Hello,

How about debug a demo project to check?

 

BR

Alice

0 Kudos
2,430 Views
DaveTonyCook
Contributor IV

How about you don't delete the readme file associated with the GIT Hub download! Thanks for your useless comment!

We are porting an existing project based on ThreadX 5.0 which uses tx_initialize_low_level.s... debugging the tx_initialize_low_level.c would not provide the information I need to make a discussion regarding risk and timescale before we start the project nor would it answer the question regarding ThreadX managed interrupts.

I found that if you download Azure ThreadX from GIT hub the tx_initialize_low_level.s file is present along with a very helpful readme file, readme_threadx.txt which explains how to deal with Managed Interrupts.

It states that ISRs for Cortex-M using the IAR tools can be written completely in C, as your demo code has been, (or assembly language) without any calls to _tx_thread_context_save or _tx_thread_context_restore. These ISRs are allowed access to the ThreadX API that is available to ISRs. This answers my original question.

If I could give some feedback:

  • It would help if the readme_threadx.txt file is kept with both the demo code and the Azure ThreadX RTOS installation.
  • Update the Azure ThreadX in the SDK or advice users to download latest from GIT Hub as Microsoft do. The O/S component of the SDK for the LPC55x (M33) is not the latest at V6.1.8. The latest from GIT Hub is V6.1.11.

I have attached the readme file for your information please refer to sec 6.1 Managed Interrupts. I hope this helps you help others with further enquiries on this topic. For the help you have provided, thank you.

 

Microsoft's Azure RTOS ThreadX for Cortex-M33

Using the IAR Tools


1. Building the ThreadX run-time Library

Import all ThreadX common and port-specific source files into an IAR project.
Configure the project to build a library rather than an executable. This
results in the ThreadX run-time library file tx.a, which is needed by
the application.
Files tx_thread_stack_error_handler.c and tx_thread_stack_error_notify.c
replace the common files of the same name.

2. Demonstration System

No demonstration is provided because the IAR EWARM 8.50 simulator does
not simulate the Cortex-M33 correctly.


3. System Initialization

The entry point in ThreadX for the Cortex-M33 using IAR tools is at label
__iar_program_start. This is defined within the IAR compiler's startup code.
In addition, this is where all static and global preset C variable
initialization processing takes place.

The ThreadX tx_initialize_low_level.s file is responsible for setting up
various system data structures, and a periodic timer interrupt source.

The _tx_initialize_low_level function inside of tx_initialize_low_level.s
also determines the first available address for use by the application, which
is supplied as the sole input parameter to your application definition function,
tx_application_define. To accomplish this, a section is created in
tx_initialize_low_level.s called FREE_MEM, which must be located after all
other RAM sections in memory.


4. Register Usage and Stack Frames

The following defines the saved context stack frames for context switches
that occur as a result of interrupt handling or from thread-level API calls.
All suspended threads have the same stack frame in the Cortex-M33 version of
ThreadX. The top of the suspended thread's stack is pointed to by
tx_thread_stack_ptr in the associated thread control block TX_THREAD.

Non-FPU Stack Frame:

Stack Offset Stack Contents

0x00 LR Interrupted LR (LR at time of PENDSV)
0x04 r4 Software stacked GP registers
0x08 r5
0x0C r6
0x10 r7
0x14 r8
0x18 r9
0x1C r10
0x20 r11
0x24 r0 Hardware stacked registers
0x28 r1
0x2C r2
0x30 r3
0x34 r12
0x38 lr
0x3C pc
0x40 xPSR

FPU Stack Frame (only interrupted thread with FPU enabled):

Stack Offset Stack Contents

0x00 LR Interrupted LR (LR at time of PENDSV)
0x04 s16 Software stacked FPU registers
0x08 s17
0x0C s18
0x10 s19
0x14 s20
0x18 s21
0x1C s22
0x20 s23
0x24 s24
0x28 s25
0x2C s26
0x30 s27
0x34 s28
0x38 s29
0x3C s30
0x40 s31
0x44 r4 Software stacked registers
0x48 r5
0x4C r6
0x50 r7
0x54 r8
0x58 r9
0x5C r10
0x60 r11
0x64 r0 Hardware stacked registers
0x68 r1
0x6C r2
0x70 r3
0x74 r12
0x78 lr
0x7C pc
0x80 xPSR
0x84 s0 Hardware stacked FPU registers
0x88 s1
0x8C s2
0x90 s3
0x94 s4
0x98 s5
0x9C s6
0xA0 s7
0xA4 s8
0xA8 s9
0xAC s10
0xB0 s11
0xB4 s12
0xB8 s13
0xBC s14
0xC0 s15
0xC4 fpscr


5. Improving Performance

To make ThreadX and the application(s) run faster, you can enable
all compiler optimizations.

In addition, you can eliminate the ThreadX basic API error checking by
compiling your application code with the symbol TX_DISABLE_ERROR_CHECKING
defined.


6. Interrupt Handling

The Cortex-M33 vectors start at the label __vector_table and is typically defined in a
startup.s file (or similar). The application may modify the vector area according to its needs.


6.1 Managed Interrupts

ISRs for Cortex-M using the IAR tools can be written completely in C (or assembly
language) without any calls to _tx_thread_context_save or _tx_thread_context_restore.
These ISRs are allowed access to the ThreadX API that is available to ISRs.

ISRs written in C will take the form (where "your_C_isr" is an entry in the vector table):

void your_C_isr(void)
{

/* ISR processing goes here, including any needed function calls. */
}

ISRs written in assembly language will take the form:

PUBLIC your_assembly_isr
your_assembly_isr:

PUSH {r0, lr}

; ISR processing goes here, including any needed function calls.

POP {r0, lr}
BX lr


7. IAR Thread-safe Library Support

Thread-safe support for the IAR tools is easily enabled by building the ThreadX library
and the application with TX_ENABLE_IAR_LIBRARY_SUPPORT. Also, the linker control file
should have the following line added (if not already in place):

initialize by copy with packing = none { section __DLIB_PERTHREAD }; // Required in a multi-threaded application


7. IAR Thread-safe Library Support

Thread-safe support for the IAR tools is easily enabled by building the ThreadX library
and the application with TX_ENABLE_IAR_LIBRARY_SUPPORT. Also, the linker control file
should have the following line added (if not already in place):

initialize by copy with packing = none { section __DLIB_PERTHREAD }; // Required in a multi-threaded application

The project options "General Options -> Library Configuration" should also have the
"Enable thread support in library" box selected.


8. VFP Support

ThreadX for Cortex-M33 supports automatic ("lazy") VFP support, which means that applications threads
can simply use the VFP and ThreadX automatically maintains the VFP registers as part of the thread
context.


9. Revision History

For generic code revision information, please refer to the readme_threadx_generic.txt
file, which is included in your distribution. The following details the revision
information associated with this specific port of ThreadX:

06-02-2021 Release 6.1.7 changes:
tx_thread_secure_stack_initialize.s New file
tx_thread_schedule.s Added secure stack initialize to SVC hander
tx_thread_secure_stack.c Fixed stack pointer save, initialize in handler mode

04-02-2021 Release 6.1.6 changes:
tx_port.h Updated macro definition
tx_thread_schedule.s Added low power support

03-02-2021 The following files were changed/added for version 6.1.5:
tx_port.h Added ULONG64_DEFINED

09-30-2020 Initial ThreadX 6.1 version for Cortex-M33 using IAR's ARM tools.


Copyright(c) 1996-2020 Microsoft Corporation


https://azure.com/rtos

 

0 Kudos