applies clang--format
This commit is contained in:
@@ -4,12 +4,14 @@
|
|||||||
#include "gen/aclint.h"
|
#include "gen/aclint.h"
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
static void set_aclint_mtime(volatile aclint_t* reg, uint64_t value) {
|
static void set_aclint_mtime(volatile aclint_t* reg, uint64_t value)
|
||||||
|
{
|
||||||
set_aclint_mtime_hi(reg, (uint32_t)(value >> 32));
|
set_aclint_mtime_hi(reg, (uint32_t)(value >> 32));
|
||||||
set_aclint_mtime_lo(reg, (uint32_t)value);
|
set_aclint_mtime_lo(reg, (uint32_t)value);
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint64_t get_aclint_mtime(volatile aclint_t* reg) {
|
static uint64_t get_aclint_mtime(volatile aclint_t* reg)
|
||||||
|
{
|
||||||
#if (__riscv_xlen == 64)
|
#if (__riscv_xlen == 64)
|
||||||
// this assume little endianness
|
// this assume little endianness
|
||||||
volatile uint64_t* mtime = (volatile uint64_t*)(uint64_t)(®->MTIME_LO);
|
volatile uint64_t* mtime = (volatile uint64_t*)(uint64_t)(®->MTIME_LO);
|
||||||
@@ -17,7 +19,8 @@ static uint64_t get_aclint_mtime(volatile aclint_t* reg) {
|
|||||||
#else
|
#else
|
||||||
uint32_t mtimeh_val;
|
uint32_t mtimeh_val;
|
||||||
uint32_t mtimel_val;
|
uint32_t mtimel_val;
|
||||||
do {
|
do
|
||||||
|
{
|
||||||
mtimeh_val = get_aclint_mtime_hi(reg);
|
mtimeh_val = get_aclint_mtime_hi(reg);
|
||||||
mtimel_val = get_aclint_mtime_lo(reg);
|
mtimel_val = get_aclint_mtime_lo(reg);
|
||||||
} while (mtimeh_val != get_aclint_mtime_hi(reg));
|
} while (mtimeh_val != get_aclint_mtime_hi(reg));
|
||||||
@@ -25,13 +28,15 @@ static uint64_t get_aclint_mtime(volatile aclint_t* reg) {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void set_aclint_mtimecmp(volatile aclint_t* reg, uint64_t value) {
|
static void set_aclint_mtimecmp(volatile aclint_t* reg, uint64_t value)
|
||||||
|
{
|
||||||
set_aclint_mtimecmp0lo(reg, (uint32_t)0xFFFFFFFF);
|
set_aclint_mtimecmp0lo(reg, (uint32_t)0xFFFFFFFF);
|
||||||
set_aclint_mtimecmp0hi(reg, (uint32_t)(value >> 32));
|
set_aclint_mtimecmp0hi(reg, (uint32_t)(value >> 32));
|
||||||
set_aclint_mtimecmp0lo(reg, (uint32_t)value);
|
set_aclint_mtimecmp0lo(reg, (uint32_t)value);
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint64_t get_aclint_mtimecmp(volatile aclint_t* reg) {
|
static uint64_t get_aclint_mtimecmp(volatile aclint_t* reg)
|
||||||
|
{
|
||||||
uint64_t value = ((uint64_t)get_aclint_mtimecmp0hi(reg) << 32) | (uint64_t)get_aclint_mtimecmp0lo(reg);
|
uint64_t value = ((uint64_t)get_aclint_mtimecmp0hi(reg) << 32) | (uint64_t)get_aclint_mtimecmp0lo(reg);
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,13 +17,15 @@
|
|||||||
#define TICKNUM_PER_SECOND 32768
|
#define TICKNUM_PER_SECOND 32768
|
||||||
#define TICKNUM_PER_TIMER (TICKNUM_PER_SECOND / 100) // ~ 1ms timer
|
#define TICKNUM_PER_TIMER (TICKNUM_PER_SECOND / 100) // ~ 1ms timer
|
||||||
|
|
||||||
static inline int hwtimer_init(void) {
|
static inline int hwtimer_init(void)
|
||||||
|
{
|
||||||
uint64_t time = get_aclint_mtime(aclint);
|
uint64_t time = get_aclint_mtime(aclint);
|
||||||
set_aclint_mtimecmp(aclint, time + TICKNUM_PER_TIMER);
|
set_aclint_mtimecmp(aclint, time + TICKNUM_PER_TIMER);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int hwtimer_handler(void) {
|
static inline int hwtimer_handler(void)
|
||||||
|
{
|
||||||
uint64_t time = get_aclint_mtime(aclint);
|
uint64_t time = get_aclint_mtime(aclint);
|
||||||
set_aclint_mtimecmp(aclint, time + TICKNUM_PER_TIMER);
|
set_aclint_mtimecmp(aclint, time + TICKNUM_PER_TIMER);
|
||||||
return 0;
|
return 0;
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#include "uart.h"
|
|
||||||
#include "gen/ethmac.h"
|
|
||||||
#include "aclint.h"
|
#include "aclint.h"
|
||||||
|
#include "gen/ethmac.h"
|
||||||
#include "riscv-csr.h"
|
#include "riscv-csr.h"
|
||||||
#include "riscv-traps.h"
|
#include "riscv-traps.h"
|
||||||
|
#include "uart.h"
|
||||||
|
|
||||||
#define PERIPH(TYPE, ADDR) ((volatile TYPE*)(ADDR))
|
#define PERIPH(TYPE, ADDR) ((volatile TYPE*)(ADDR))
|
||||||
#define PERIPH_BASE 0x10000000
|
#define PERIPH_BASE 0x10000000
|
||||||
@@ -21,4 +21,3 @@
|
|||||||
#define GPIO_ORQ 23
|
#define GPIO_ORQ 23
|
||||||
#define ETH0_IRQ 24
|
#define ETH0_IRQ 24
|
||||||
#define ETH1_IRQ 25
|
#define ETH1_IRQ 25
|
||||||
|
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -9,7 +9,8 @@
|
|||||||
#ifndef RISCV_TRAPS_H
|
#ifndef RISCV_TRAPS_H
|
||||||
#define RISCV_TRAPS_H
|
#define RISCV_TRAPS_H
|
||||||
|
|
||||||
enum {
|
enum
|
||||||
|
{
|
||||||
RISCV_INT_MSI = 3,
|
RISCV_INT_MSI = 3,
|
||||||
RISCV_INT_MTI = 7,
|
RISCV_INT_MTI = 7,
|
||||||
RISCV_INT_MEI = 11,
|
RISCV_INT_MEI = 11,
|
||||||
@@ -21,7 +22,8 @@ enum {
|
|||||||
RISCV_INT_UEI = 8,
|
RISCV_INT_UEI = 8,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
enum
|
||||||
|
{
|
||||||
RISCV_INT_POS_MSI = 3,
|
RISCV_INT_POS_MSI = 3,
|
||||||
RISCV_INT_POS_MTI = 7,
|
RISCV_INT_POS_MTI = 7,
|
||||||
RISCV_INT_POS_MEI = 11,
|
RISCV_INT_POS_MEI = 11,
|
||||||
@@ -33,7 +35,8 @@ enum {
|
|||||||
RISCV_INT_POS_UEI = 8,
|
RISCV_INT_POS_UEI = 8,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
enum
|
||||||
|
{
|
||||||
RISCV_INT_MASK_MSI = (1UL << RISCV_INT_POS_MSI),
|
RISCV_INT_MASK_MSI = (1UL << RISCV_INT_POS_MSI),
|
||||||
RISCV_INT_MASK_MTI = (1UL << RISCV_INT_POS_MTI),
|
RISCV_INT_MASK_MTI = (1UL << RISCV_INT_POS_MTI),
|
||||||
RISCV_INT_MASK_MEI = (1UL << RISCV_INT_POS_MEI),
|
RISCV_INT_MASK_MEI = (1UL << RISCV_INT_POS_MEI),
|
||||||
@@ -45,7 +48,8 @@ enum {
|
|||||||
RISCV_INT_MASK_UEI = (1UL << RISCV_INT_POS_UEI),
|
RISCV_INT_MASK_UEI = (1UL << RISCV_INT_POS_UEI),
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
enum
|
||||||
|
{
|
||||||
RISCV_EXCP_INSTRUCTION_ADDRESS_MISALIGNED = 0, /* Instruction address misaligned */
|
RISCV_EXCP_INSTRUCTION_ADDRESS_MISALIGNED = 0, /* Instruction address misaligned */
|
||||||
RISCV_EXCP_INSTRUCTION_ACCESS_FAULT = 1, /* Instruction access fault */
|
RISCV_EXCP_INSTRUCTION_ACCESS_FAULT = 1, /* Instruction access fault */
|
||||||
RISCV_EXCP_ILLEGAL_INSTRUCTION = 2, /* Illegal instruction */
|
RISCV_EXCP_ILLEGAL_INSTRUCTION = 2, /* Illegal instruction */
|
||||||
@@ -64,5 +68,4 @@ enum {
|
|||||||
RISCV_EXCP_STORE_AMO_PAGE_FAULT = 15, /* Store/AMO page fault */
|
RISCV_EXCP_STORE_AMO_PAGE_FAULT = 15, /* Store/AMO page fault */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#endif /* RISCV_TRAPS_H */
|
#endif /* RISCV_TRAPS_H */
|
||||||
@@ -3,19 +3,30 @@
|
|||||||
#include "gen/uart.h"
|
#include "gen/uart.h"
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
static inline uint32_t uart_get_tx_free(volatile uart_t* reg) { return get_uart_rx_tx_reg_tx_free(reg); }
|
static inline uint32_t uart_get_tx_free(volatile uart_t* reg)
|
||||||
|
{
|
||||||
|
return get_uart_rx_tx_reg_tx_free(reg);
|
||||||
|
}
|
||||||
|
|
||||||
static inline uint32_t uart_get_tx_empty(volatile uart_t* reg) { return get_uart_rx_tx_reg_tx_empty(reg); }
|
static inline uint32_t uart_get_tx_empty(volatile uart_t* reg)
|
||||||
|
{
|
||||||
|
return get_uart_rx_tx_reg_tx_empty(reg);
|
||||||
|
}
|
||||||
|
|
||||||
static inline uint32_t uart_get_rx_avail(volatile uart_t* reg) { return get_uart_rx_tx_reg_rx_avail(reg); }
|
static inline uint32_t uart_get_rx_avail(volatile uart_t* reg)
|
||||||
|
{
|
||||||
|
return get_uart_rx_tx_reg_rx_avail(reg);
|
||||||
|
}
|
||||||
|
|
||||||
static inline void uart_write(volatile uart_t* reg, uint8_t data) {
|
static inline void uart_write(volatile uart_t* reg, uint8_t data)
|
||||||
|
{
|
||||||
while (get_uart_rx_tx_reg_tx_free(reg) == 0)
|
while (get_uart_rx_tx_reg_tx_free(reg) == 0)
|
||||||
;
|
;
|
||||||
set_uart_rx_tx_reg_data(reg, data);
|
set_uart_rx_tx_reg_data(reg, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline uint8_t uart_read(volatile uart_t* reg) {
|
static inline uint8_t uart_read(volatile uart_t* reg)
|
||||||
|
{
|
||||||
uint32_t res = get_uart_rx_tx_reg_data(reg);
|
uint32_t res = get_uart_rx_tx_reg_data(reg);
|
||||||
while ((res & 0x10000) == 0)
|
while ((res & 0x10000) == 0)
|
||||||
res = get_uart_rx_tx_reg_data(reg);
|
res = get_uart_rx_tx_reg_data(reg);
|
||||||
|
|||||||
@@ -17,7 +17,6 @@
|
|||||||
#ifndef VECTOR_TABLE_H
|
#ifndef VECTOR_TABLE_H
|
||||||
#define VECTOR_TABLE_H
|
#define VECTOR_TABLE_H
|
||||||
|
|
||||||
|
|
||||||
/** Symbol for machine mode vector table - do not call
|
/** Symbol for machine mode vector table - do not call
|
||||||
*/
|
*/
|
||||||
void riscv_mtvec_table(void) __attribute__((naked));
|
void riscv_mtvec_table(void) __attribute__((naked));
|
||||||
@@ -106,8 +105,6 @@ void riscv_mtvec_platform_irq14(void) __attribute__ ((interrupt ("machine")) );
|
|||||||
/* Platform interrupt 15, bit 31 of mip/mie */
|
/* Platform interrupt 15, bit 31 of mip/mie */
|
||||||
void riscv_mtvec_platform_irq15(void) __attribute__((interrupt("machine")));
|
void riscv_mtvec_platform_irq15(void) __attribute__((interrupt("machine")));
|
||||||
|
|
||||||
|
|
||||||
#endif // #ifndef VECTOR_TABLE_MTVEC_PLATFORM_INTS
|
#endif // #ifndef VECTOR_TABLE_MTVEC_PLATFORM_INTS
|
||||||
|
|
||||||
|
|
||||||
#endif // #ifndef VECTOR_TABLE_H
|
#endif // #ifndef VECTOR_TABLE_H
|
||||||
@@ -8,11 +8,9 @@
|
|||||||
* SPDX-License-Identifier: MIT
|
* SPDX-License-Identifier: MIT
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#ifndef CSR_H
|
#ifndef CSR_H
|
||||||
#define CSR_H
|
#define CSR_H
|
||||||
|
|
||||||
|
|
||||||
// Machine Status Register, mstatus
|
// Machine Status Register, mstatus
|
||||||
#define MSTATUS_MPP_MASK (3L << 11) // previous mode.
|
#define MSTATUS_MPP_MASK (3L << 11) // previous mode.
|
||||||
#define MSTATUS_MPP_M (3L << 11)
|
#define MSTATUS_MPP_M (3L << 11)
|
||||||
|
|||||||
@@ -131,7 +131,8 @@
|
|||||||
extern volatile ULONG TX_THREAD_GET_SYSTEM_STATE();
|
extern volatile ULONG TX_THREAD_GET_SYSTEM_STATE();
|
||||||
|
|
||||||
#define NX_THREADS_ONLY_CALLER_CHECKING \
|
#define NX_THREADS_ONLY_CALLER_CHECKING \
|
||||||
if((TX_THREAD_GET_SYSTEM_STATE()) || (_tx_thread_current_ptr == TX_NULL) || (_tx_thread_current_ptr == &_tx_timer_thread)) \
|
if ((TX_THREAD_GET_SYSTEM_STATE()) || (_tx_thread_current_ptr == TX_NULL) || \
|
||||||
|
(_tx_thread_current_ptr == &_tx_timer_thread)) \
|
||||||
return (NX_CALLER_ERROR);
|
return (NX_CALLER_ERROR);
|
||||||
|
|
||||||
#define NX_INIT_AND_THREADS_CALLER_CHECKING \
|
#define NX_INIT_AND_THREADS_CALLER_CHECKING \
|
||||||
@@ -144,8 +145,8 @@
|
|||||||
return (NX_CALLER_ERROR);
|
return (NX_CALLER_ERROR);
|
||||||
|
|
||||||
#define NX_THREAD_WAIT_CALLER_CHECKING \
|
#define NX_THREAD_WAIT_CALLER_CHECKING \
|
||||||
if((wait_option) && \
|
if ((wait_option) && ((_tx_thread_current_ptr == NX_NULL) || (TX_THREAD_GET_SYSTEM_STATE()) || \
|
||||||
((_tx_thread_current_ptr == NX_NULL) || (TX_THREAD_GET_SYSTEM_STATE()) || (_tx_thread_current_ptr == &_tx_timer_thread))) \
|
(_tx_thread_current_ptr == &_tx_timer_thread))) \
|
||||||
return (NX_CALLER_ERROR);
|
return (NX_CALLER_ERROR);
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|||||||
@@ -765,7 +765,8 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C"
|
||||||
|
{
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int rand(void);
|
int rand(void);
|
||||||
|
|||||||
@@ -248,7 +248,9 @@ ULONG64 _tx_thread_interrupt_control(unsigned int new_posture);
|
|||||||
#define TX_INTERRUPT_SAVE_AREA ULONG64 interrupt_save;
|
#define TX_INTERRUPT_SAVE_AREA ULONG64 interrupt_save;
|
||||||
/* Atomically read mstatus into interrupt_save and clear bit 3 of mstatus. */
|
/* Atomically read mstatus into interrupt_save and clear bit 3 of mstatus. */
|
||||||
#define TX_DISABLE \
|
#define TX_DISABLE \
|
||||||
{ __asm__("csrrci %0, mstatus, 0x08" : "=r"(interrupt_save) :); };
|
{ \
|
||||||
|
__asm__("csrrci %0, mstatus, 0x08" : "=r"(interrupt_save) :); \
|
||||||
|
};
|
||||||
/* We only care about mstatus.mie (bit 3), so mask interrupt_save and write to mstatus. */
|
/* We only care about mstatus.mie (bit 3), so mask interrupt_save and write to mstatus. */
|
||||||
#define TX_RESTORE \
|
#define TX_RESTORE \
|
||||||
{ \
|
{ \
|
||||||
|
|||||||
@@ -8,7 +8,6 @@
|
|||||||
* SPDX-License-Identifier: MIT
|
* SPDX-License-Identifier: MIT
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
/** */
|
/** */
|
||||||
@@ -19,7 +18,6 @@
|
|||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
/* */
|
/* */
|
||||||
/* PORT SPECIFIC C INFORMATION RELEASE */
|
/* PORT SPECIFIC C INFORMATION RELEASE */
|
||||||
@@ -71,7 +69,6 @@
|
|||||||
#ifndef TX_USER_H
|
#ifndef TX_USER_H
|
||||||
#define TX_USER_H
|
#define TX_USER_H
|
||||||
|
|
||||||
|
|
||||||
/* Define various build options for the ThreadX port. The application should either make changes
|
/* Define various build options for the ThreadX port. The application should either make changes
|
||||||
here by commenting or un-commenting the conditional compilation defined OR supply the defines
|
here by commenting or un-commenting the conditional compilation defined OR supply the defines
|
||||||
though the compiler's equivalent of the -D option.
|
though the compiler's equivalent of the -D option.
|
||||||
@@ -105,7 +102,6 @@
|
|||||||
therefore return an error if this option is used. This may or may not be desirable for a
|
therefore return an error if this option is used. This may or may not be desirable for a
|
||||||
given application. */
|
given application. */
|
||||||
|
|
||||||
|
|
||||||
/* Override various options with default values already assigned in tx_port.h. Please also refer
|
/* Override various options with default values already assigned in tx_port.h. Please also refer
|
||||||
to tx_port.h for descriptions on each of these options. */
|
to tx_port.h for descriptions on each of these options. */
|
||||||
|
|
||||||
@@ -129,10 +125,8 @@
|
|||||||
version in tx_port.h or here.
|
version in tx_port.h or here.
|
||||||
Note: the actual hardware timer value may need to be changed (usually in tx_initialize_low_level). */
|
Note: the actual hardware timer value may need to be changed (usually in tx_initialize_low_level). */
|
||||||
|
|
||||||
|
|
||||||
#define TX_TIMER_TICKS_PER_SECOND (100) // for moonlight with 32,7kHz Frequency (divided by 1000)
|
#define TX_TIMER_TICKS_PER_SECOND (100) // for moonlight with 32,7kHz Frequency (divided by 1000)
|
||||||
|
|
||||||
|
|
||||||
/* Determine if there is a FileX pointer in the thread control block.
|
/* Determine if there is a FileX pointer in the thread control block.
|
||||||
By default, the pointer is there for legacy/backwards compatibility.
|
By default, the pointer is there for legacy/backwards compatibility.
|
||||||
The pointer must also be there for applications using FileX.
|
The pointer must also be there for applications using FileX.
|
||||||
@@ -225,7 +219,6 @@
|
|||||||
#define TX_DISABLE_NOTIFY_CALLBACKS
|
#define TX_DISABLE_NOTIFY_CALLBACKS
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/* Determine if the tx_thread_resume and tx_thread_suspend services should have their internal
|
/* Determine if the tx_thread_resume and tx_thread_suspend services should have their internal
|
||||||
code in-line. This results in a larger image, but improves the performance of the thread
|
code in-line. This results in a larger image, but improves the performance of the thread
|
||||||
resume and suspend services. */
|
resume and suspend services. */
|
||||||
@@ -234,7 +227,6 @@
|
|||||||
#define TX_INLINE_THREAD_RESUME_SUSPEND
|
#define TX_INLINE_THREAD_RESUME_SUSPEND
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/* Determine if the internal ThreadX code is non-interruptable. This results in smaller code
|
/* Determine if the internal ThreadX code is non-interruptable. This results in smaller code
|
||||||
size and less processing overhead, but increases the interrupt lockout time. */
|
size and less processing overhead, but increases the interrupt lockout time. */
|
||||||
|
|
||||||
@@ -242,7 +234,6 @@
|
|||||||
#define TX_NOT_INTERRUPTABLE
|
#define TX_NOT_INTERRUPTABLE
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/* Determine if the trace event logging code should be enabled. This causes slight increases in
|
/* Determine if the trace event logging code should be enabled. This causes slight increases in
|
||||||
code size and overhead, but provides the ability to generate system trace information which
|
code size and overhead, but provides the ability to generate system trace information which
|
||||||
is available for viewing in TraceX. */
|
is available for viewing in TraceX. */
|
||||||
@@ -251,7 +242,6 @@
|
|||||||
#define TX_ENABLE_EVENT_TRACE
|
#define TX_ENABLE_EVENT_TRACE
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/* Determine if block pool performance gathering is required by the application. When the following is
|
/* Determine if block pool performance gathering is required by the application. When the following is
|
||||||
defined, ThreadX gathers various block pool performance information. */
|
defined, ThreadX gathers various block pool performance information. */
|
||||||
|
|
||||||
@@ -321,4 +311,3 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|||||||
@@ -44,13 +44,15 @@ void _nx_mnrs_network_driver(struct NX_IP_DRIVER_STRUCT* driver_req);
|
|||||||
|
|
||||||
/* Define main entry point. */
|
/* Define main entry point. */
|
||||||
|
|
||||||
int main() {
|
int main()
|
||||||
|
{
|
||||||
/* Enter the ThreadX kernel. */
|
/* Enter the ThreadX kernel. */
|
||||||
tx_kernel_enter();
|
tx_kernel_enter();
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Define what the initial system looks like. */
|
/* Define what the initial system looks like. */
|
||||||
void tx_application_define(void* first_unused_memory) {
|
void tx_application_define(void* first_unused_memory)
|
||||||
|
{
|
||||||
CHAR* pointer;
|
CHAR* pointer;
|
||||||
UINT status;
|
UINT status;
|
||||||
puts("Setting up application");
|
puts("Setting up application");
|
||||||
@@ -58,12 +60,14 @@ void tx_application_define(void* first_unused_memory) {
|
|||||||
pointer = (CHAR*)first_unused_memory;
|
pointer = (CHAR*)first_unused_memory;
|
||||||
|
|
||||||
/* Create the main thread. */
|
/* Create the main thread. */
|
||||||
tx_thread_create(&thread_0, "thread 0", thread_0_entry, 0, pointer, DEMO_STACK_SIZE, 4, 4, TX_NO_TIME_SLICE, TX_AUTO_START);
|
tx_thread_create(
|
||||||
|
&thread_0, "thread 0", thread_0_entry, 0, pointer, DEMO_STACK_SIZE, 4, 4, TX_NO_TIME_SLICE, TX_AUTO_START);
|
||||||
|
|
||||||
pointer = pointer + DEMO_STACK_SIZE;
|
pointer = pointer + DEMO_STACK_SIZE;
|
||||||
|
|
||||||
/* Create the main thread. */
|
/* Create the main thread. */
|
||||||
tx_thread_create(&thread_1, "thread 1", thread_1_entry, 0, pointer, DEMO_STACK_SIZE, 3, 3, TX_NO_TIME_SLICE, TX_AUTO_START);
|
tx_thread_create(
|
||||||
|
&thread_1, "thread 1", thread_1_entry, 0, pointer, DEMO_STACK_SIZE, 3, 3, TX_NO_TIME_SLICE, TX_AUTO_START);
|
||||||
|
|
||||||
pointer = pointer + DEMO_STACK_SIZE;
|
pointer = pointer + DEMO_STACK_SIZE;
|
||||||
|
|
||||||
@@ -73,19 +77,23 @@ void tx_application_define(void* first_unused_memory) {
|
|||||||
/* Create a packet pool. */
|
/* Create a packet pool. */
|
||||||
status = nx_packet_pool_create(&pool_0, "packet_pool0", PACKET_SIZE, pool_buffer, POOL_SIZE);
|
status = nx_packet_pool_create(&pool_0, "packet_pool0", PACKET_SIZE, pool_buffer, POOL_SIZE);
|
||||||
|
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Create an IP instance. */
|
/* Create an IP instance. */
|
||||||
status = nx_ip_create(&ip_0, "eth0", IP_ADDRESS(1, 2, 3, 4), 0xFFFFFF00UL, &pool_0, NETWORK_DRIVER, pointer, 2048, 1);
|
status =
|
||||||
|
nx_ip_create(&ip_0, "eth0", IP_ADDRESS(1, 2, 3, 4), 0xFFFFFF00UL, &pool_0, NETWORK_DRIVER, pointer, 2048, 1);
|
||||||
pointer = pointer + 2048;
|
pointer = pointer + 2048;
|
||||||
|
|
||||||
/* Create another IP instance. */
|
/* Create another IP instance. */
|
||||||
status += nx_ip_create(&ip_1, "eth1", IP_ADDRESS(1, 2, 3, 5), 0xFFFFFF00UL, &pool_0, NETWORK_DRIVER, pointer, 2048, 1);
|
status +=
|
||||||
|
nx_ip_create(&ip_1, "eth1", IP_ADDRESS(1, 2, 3, 5), 0xFFFFFF00UL, &pool_0, NETWORK_DRIVER, pointer, 2048, 1);
|
||||||
pointer = pointer + 2048;
|
pointer = pointer + 2048;
|
||||||
|
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -98,18 +106,21 @@ void tx_application_define(void* first_unused_memory) {
|
|||||||
pointer = pointer + 1024;
|
pointer = pointer + 1024;
|
||||||
|
|
||||||
/* Check ARP enable status. */
|
/* Check ARP enable status. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Enable ICMP */
|
/* Enable ICMP */
|
||||||
status = nxd_icmp_enable(&ip_0);
|
status = nxd_icmp_enable(&ip_0);
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
status = nxd_icmp_enable(&ip_1);
|
status = nxd_icmp_enable(&ip_1);
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -122,7 +133,8 @@ void tx_application_define(void* first_unused_memory) {
|
|||||||
|
|
||||||
/* Define the test threads. */
|
/* Define the test threads. */
|
||||||
|
|
||||||
void thread_0_entry(ULONG thread_input) {
|
void thread_0_entry(ULONG thread_input)
|
||||||
|
{
|
||||||
|
|
||||||
UINT status;
|
UINT status;
|
||||||
NX_PACKET* my_packet;
|
NX_PACKET* my_packet;
|
||||||
@@ -142,14 +154,23 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
server_ipv4_address.nxd_ip_address.v4 = IP_ADDRESS(1, 2, 3, 5);
|
server_ipv4_address.nxd_ip_address.v4 = IP_ADDRESS(1, 2, 3, 5);
|
||||||
/* Loop to repeat things over and over again! */
|
/* Loop to repeat things over and over again! */
|
||||||
puts("Entering client loop");
|
puts("Entering client loop");
|
||||||
while(1) {
|
while (1)
|
||||||
|
{
|
||||||
|
|
||||||
/* Create a socket. */
|
/* Create a socket. */
|
||||||
status = nx_tcp_socket_create(&ip_0, &client_socket, "Client Socket", NX_IP_NORMAL, NX_FRAGMENT_OKAY, NX_IP_TIME_TO_LIVE, 200,
|
status = nx_tcp_socket_create(&ip_0,
|
||||||
NX_NULL, NX_NULL);
|
&client_socket,
|
||||||
|
"Client Socket",
|
||||||
|
NX_IP_NORMAL,
|
||||||
|
NX_FRAGMENT_OKAY,
|
||||||
|
NX_IP_TIME_TO_LIVE,
|
||||||
|
200,
|
||||||
|
NX_NULL,
|
||||||
|
NX_NULL);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -157,7 +178,8 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_client_socket_bind(&client_socket, 12, NX_WAIT_FOREVER);
|
status = nx_tcp_client_socket_bind(&client_socket, 12, NX_WAIT_FOREVER);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -165,7 +187,8 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
status = nxd_tcp_client_socket_connect(&client_socket, &server_ipv4_address, 12, NX_IP_PERIODIC_RATE);
|
status = nxd_tcp_client_socket_connect(&client_socket, &server_ipv4_address, 12, NX_IP_PERIODIC_RATE);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
printf("Error with socket connect: 0x%x\n", status);
|
printf("Error with socket connect: 0x%x\n", status);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -176,7 +199,8 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
status = nx_packet_allocate(&pool_0, &my_packet, NX_TCP_PACKET, NX_WAIT_FOREVER);
|
status = nx_packet_allocate(&pool_0, &my_packet, NX_TCP_PACKET, NX_WAIT_FOREVER);
|
||||||
|
|
||||||
/* Check status. */
|
/* Check status. */
|
||||||
if(status != NX_SUCCESS) {
|
if (status != NX_SUCCESS)
|
||||||
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -184,7 +208,8 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
nx_packet_data_append(my_packet, DEMO_DATA, sizeof(DEMO_DATA), &pool_0, TX_WAIT_FOREVER);
|
nx_packet_data_append(my_packet, DEMO_DATA, sizeof(DEMO_DATA), &pool_0, TX_WAIT_FOREVER);
|
||||||
|
|
||||||
status = nx_packet_length_get(my_packet, &length);
|
status = nx_packet_length_get(my_packet, &length);
|
||||||
if((status) || (length != sizeof(DEMO_DATA))) {
|
if ((status) || (length != sizeof(DEMO_DATA)))
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -192,7 +217,8 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_socket_send(&client_socket, my_packet, NX_IP_PERIODIC_RATE);
|
status = nx_tcp_socket_send(&client_socket, my_packet, NX_IP_PERIODIC_RATE);
|
||||||
|
|
||||||
/* Determine if the status is valid. */
|
/* Determine if the status is valid. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
nx_packet_release(my_packet);
|
nx_packet_release(my_packet);
|
||||||
}
|
}
|
||||||
@@ -201,7 +227,8 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_socket_disconnect(&client_socket, NX_IP_PERIODIC_RATE);
|
status = nx_tcp_socket_disconnect(&client_socket, NX_IP_PERIODIC_RATE);
|
||||||
|
|
||||||
/* Determine if the status is valid. */
|
/* Determine if the status is valid. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -209,7 +236,8 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_client_socket_unbind(&client_socket);
|
status = nx_tcp_client_socket_unbind(&client_socket);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -217,7 +245,8 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_socket_delete(&client_socket);
|
status = nx_tcp_socket_delete(&client_socket);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -226,7 +255,8 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void thread_1_entry(ULONG thread_input) {
|
void thread_1_entry(ULONG thread_input)
|
||||||
|
{
|
||||||
|
|
||||||
UINT status;
|
UINT status;
|
||||||
NX_PACKET* packet_ptr;
|
NX_PACKET* packet_ptr;
|
||||||
@@ -241,18 +271,27 @@ void thread_1_entry(ULONG thread_input) {
|
|||||||
status = nx_ip_status_check(&ip_1, NX_IP_INITIALIZE_DONE, &actual_status, NX_IP_PERIODIC_RATE);
|
status = nx_ip_status_check(&ip_1, NX_IP_INITIALIZE_DONE, &actual_status, NX_IP_PERIODIC_RATE);
|
||||||
|
|
||||||
/* Check status... */
|
/* Check status... */
|
||||||
if(status != NX_SUCCESS) {
|
if (status != NX_SUCCESS)
|
||||||
|
{
|
||||||
|
|
||||||
error_counter++;
|
error_counter++;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Create a socket. */
|
/* Create a socket. */
|
||||||
status = nx_tcp_socket_create(&ip_1, &server_socket, "Server Socket", NX_IP_NORMAL, NX_FRAGMENT_OKAY, NX_IP_TIME_TO_LIVE, 100, NX_NULL,
|
status = nx_tcp_socket_create(&ip_1,
|
||||||
|
&server_socket,
|
||||||
|
"Server Socket",
|
||||||
|
NX_IP_NORMAL,
|
||||||
|
NX_FRAGMENT_OKAY,
|
||||||
|
NX_IP_TIME_TO_LIVE,
|
||||||
|
100,
|
||||||
|
NX_NULL,
|
||||||
thread_1_disconnect_received);
|
thread_1_disconnect_received);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -260,13 +299,15 @@ void thread_1_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_server_socket_listen(&ip_1, 12, &server_socket, 5, thread_1_connect_received);
|
status = nx_tcp_server_socket_listen(&ip_1, 12, &server_socket, 5, thread_1_connect_received);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Loop to create and establish server connections. */
|
/* Loop to create and establish server connections. */
|
||||||
puts("Entering server loop");
|
puts("Entering server loop");
|
||||||
while(1) {
|
while (1)
|
||||||
|
{
|
||||||
|
|
||||||
/* Increment thread 1's counter. */
|
/* Increment thread 1's counter. */
|
||||||
thread_1_counter++;
|
thread_1_counter++;
|
||||||
@@ -275,7 +316,8 @@ void thread_1_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_server_socket_accept(&server_socket, NX_WAIT_FOREVER);
|
status = nx_tcp_server_socket_accept(&server_socket, NX_WAIT_FOREVER);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -283,9 +325,12 @@ void thread_1_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_socket_receive(&server_socket, &packet_ptr, NX_IP_PERIODIC_RATE);
|
status = nx_tcp_socket_receive(&server_socket, &packet_ptr, NX_IP_PERIODIC_RATE);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
char buffer[64];
|
char buffer[64];
|
||||||
ULONG size;
|
ULONG size;
|
||||||
nx_packet_data_extract_offset(packet_ptr, 0, buffer, 64, &size);
|
nx_packet_data_extract_offset(packet_ptr, 0, buffer, 64, &size);
|
||||||
@@ -299,7 +344,8 @@ void thread_1_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_socket_disconnect(&server_socket, NX_IP_PERIODIC_RATE);
|
status = nx_tcp_socket_disconnect(&server_socket, NX_IP_PERIODIC_RATE);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -307,7 +353,8 @@ void thread_1_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_server_socket_unaccept(&server_socket);
|
status = nx_tcp_server_socket_unaccept(&server_socket);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -315,24 +362,29 @@ void thread_1_entry(ULONG thread_input) {
|
|||||||
status = nx_tcp_server_socket_relisten(&ip_1, 12, &server_socket);
|
status = nx_tcp_server_socket_relisten(&ip_1, 12, &server_socket);
|
||||||
|
|
||||||
/* Check for error. */
|
/* Check for error. */
|
||||||
if(status) {
|
if (status)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void thread_1_connect_received(NX_TCP_SOCKET* socket_ptr, UINT port) {
|
void thread_1_connect_received(NX_TCP_SOCKET* socket_ptr, UINT port)
|
||||||
|
{
|
||||||
|
|
||||||
/* Check for the proper socket and port. */
|
/* Check for the proper socket and port. */
|
||||||
if((socket_ptr != &server_socket) || (port != 12)) {
|
if ((socket_ptr != &server_socket) || (port != 12))
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void thread_1_disconnect_received(NX_TCP_SOCKET* socket) {
|
void thread_1_disconnect_received(NX_TCP_SOCKET* socket)
|
||||||
|
{
|
||||||
|
|
||||||
/* Check for proper disconnected socket. */
|
/* Check for proper disconnected socket. */
|
||||||
if(socket != &server_socket) {
|
if (socket != &server_socket)
|
||||||
|
{
|
||||||
error_counter++;
|
error_counter++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -51,14 +51,16 @@ void thread_5_entry(ULONG thread_input);
|
|||||||
void thread_6_and_7_entry(ULONG thread_input);
|
void thread_6_and_7_entry(ULONG thread_input);
|
||||||
|
|
||||||
/* Define main entry point. */
|
/* Define main entry point. */
|
||||||
int main() {
|
int main()
|
||||||
|
{
|
||||||
/* Enter the ThreadX kernel. */
|
/* Enter the ThreadX kernel. */
|
||||||
tx_kernel_enter();
|
tx_kernel_enter();
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Define what the initial system looks like. */
|
/* Define what the initial system looks like. */
|
||||||
|
|
||||||
void tx_application_define(void* first_unused_memory) {
|
void tx_application_define(void* first_unused_memory)
|
||||||
|
{
|
||||||
|
|
||||||
CHAR* pointer = TX_NULL;
|
CHAR* pointer = TX_NULL;
|
||||||
|
|
||||||
@@ -72,7 +74,8 @@ void tx_application_define(void* first_unused_memory) {
|
|||||||
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
||||||
|
|
||||||
/* Create the main thread. */
|
/* Create the main thread. */
|
||||||
tx_thread_create(&thread_0, "thread 0", thread_0_entry, 0, pointer, DEMO_STACK_SIZE, 1, 1, TX_NO_TIME_SLICE, TX_AUTO_START);
|
tx_thread_create(
|
||||||
|
&thread_0, "thread 0", thread_0_entry, 0, pointer, DEMO_STACK_SIZE, 1, 1, TX_NO_TIME_SLICE, TX_AUTO_START);
|
||||||
|
|
||||||
/* Allocate the stack for thread 1. */
|
/* Allocate the stack for thread 1. */
|
||||||
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
||||||
@@ -93,30 +96,67 @@ void tx_application_define(void* first_unused_memory) {
|
|||||||
/* Create threads 3 and 4. These threads compete for a ThreadX counting
|
/* Create threads 3 and 4. These threads compete for a ThreadX counting
|
||||||
semaphore. An interesting thing here is that both threads share the same
|
semaphore. An interesting thing here is that both threads share the same
|
||||||
instruction area. */
|
instruction area. */
|
||||||
tx_thread_create(&thread_3, "thread 3", thread_3_and_4_entry, 3, pointer, DEMO_STACK_SIZE, 8, 8, TX_NO_TIME_SLICE, TX_AUTO_START);
|
tx_thread_create(&thread_3,
|
||||||
|
"thread 3",
|
||||||
|
thread_3_and_4_entry,
|
||||||
|
3,
|
||||||
|
pointer,
|
||||||
|
DEMO_STACK_SIZE,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
TX_NO_TIME_SLICE,
|
||||||
|
TX_AUTO_START);
|
||||||
|
|
||||||
/* Allocate the stack for thread 4. */
|
/* Allocate the stack for thread 4. */
|
||||||
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
||||||
|
|
||||||
tx_thread_create(&thread_4, "thread 4", thread_3_and_4_entry, 4, pointer, DEMO_STACK_SIZE, 8, 8, TX_NO_TIME_SLICE, TX_AUTO_START);
|
tx_thread_create(&thread_4,
|
||||||
|
"thread 4",
|
||||||
|
thread_3_and_4_entry,
|
||||||
|
4,
|
||||||
|
pointer,
|
||||||
|
DEMO_STACK_SIZE,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
TX_NO_TIME_SLICE,
|
||||||
|
TX_AUTO_START);
|
||||||
|
|
||||||
/* Allocate the stack for thread 5. */
|
/* Allocate the stack for thread 5. */
|
||||||
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
||||||
|
|
||||||
/* Create thread 5. This thread simply pends on an event flag which will be
|
/* Create thread 5. This thread simply pends on an event flag which will be
|
||||||
set by thread_0. */
|
set by thread_0. */
|
||||||
tx_thread_create(&thread_5, "thread 5", thread_5_entry, 5, pointer, DEMO_STACK_SIZE, 4, 4, TX_NO_TIME_SLICE, TX_AUTO_START);
|
tx_thread_create(
|
||||||
|
&thread_5, "thread 5", thread_5_entry, 5, pointer, DEMO_STACK_SIZE, 4, 4, TX_NO_TIME_SLICE, TX_AUTO_START);
|
||||||
|
|
||||||
/* Allocate the stack for thread 6. */
|
/* Allocate the stack for thread 6. */
|
||||||
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
||||||
|
|
||||||
/* Create threads 6 and 7. These threads compete for a ThreadX mutex. */
|
/* Create threads 6 and 7. These threads compete for a ThreadX mutex. */
|
||||||
tx_thread_create(&thread_6, "thread 6", thread_6_and_7_entry, 6, pointer, DEMO_STACK_SIZE, 8, 8, TX_NO_TIME_SLICE, TX_AUTO_START);
|
tx_thread_create(&thread_6,
|
||||||
|
"thread 6",
|
||||||
|
thread_6_and_7_entry,
|
||||||
|
6,
|
||||||
|
pointer,
|
||||||
|
DEMO_STACK_SIZE,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
TX_NO_TIME_SLICE,
|
||||||
|
TX_AUTO_START);
|
||||||
|
|
||||||
/* Allocate the stack for thread 7. */
|
/* Allocate the stack for thread 7. */
|
||||||
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_STACK_SIZE, TX_NO_WAIT);
|
||||||
|
|
||||||
tx_thread_create(&thread_7, "thread 7", thread_6_and_7_entry, 7, pointer, DEMO_STACK_SIZE, 8, 8, TX_NO_TIME_SLICE, TX_AUTO_START);
|
tx_thread_create(&thread_7,
|
||||||
|
"thread 7",
|
||||||
|
thread_6_and_7_entry,
|
||||||
|
7,
|
||||||
|
pointer,
|
||||||
|
DEMO_STACK_SIZE,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
TX_NO_TIME_SLICE,
|
||||||
|
TX_AUTO_START);
|
||||||
|
|
||||||
/* Allocate the message queue. */
|
/* Allocate the message queue. */
|
||||||
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_QUEUE_SIZE * sizeof(ULONG), TX_NO_WAIT);
|
tx_byte_allocate(&byte_pool_0, (VOID**)&pointer, DEMO_QUEUE_SIZE * sizeof(ULONG), TX_NO_WAIT);
|
||||||
@@ -148,12 +188,14 @@ void tx_application_define(void* first_unused_memory) {
|
|||||||
|
|
||||||
/* Define the test threads. */
|
/* Define the test threads. */
|
||||||
|
|
||||||
void thread_0_entry(ULONG thread_input) {
|
void thread_0_entry(ULONG thread_input)
|
||||||
|
{
|
||||||
|
|
||||||
UINT status;
|
UINT status;
|
||||||
|
|
||||||
/* This thread simply sits in while-forever-sleep loop. */
|
/* This thread simply sits in while-forever-sleep loop. */
|
||||||
while(1) {
|
while (1)
|
||||||
|
{
|
||||||
puts("[Thread] : thread_0_entry is here!");
|
puts("[Thread] : thread_0_entry is here!");
|
||||||
/* Increment the thread counter. */
|
/* Increment the thread counter. */
|
||||||
thread_0_counter++;
|
thread_0_counter++;
|
||||||
@@ -170,12 +212,14 @@ void thread_0_entry(ULONG thread_input) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void thread_1_entry(ULONG thread_input) {
|
void thread_1_entry(ULONG thread_input)
|
||||||
|
{
|
||||||
|
|
||||||
UINT status;
|
UINT status;
|
||||||
|
|
||||||
/* This thread simply sends messages to a queue shared by thread 2. */
|
/* This thread simply sends messages to a queue shared by thread 2. */
|
||||||
while(1) {
|
while (1)
|
||||||
|
{
|
||||||
/* Increment the thread counter. */
|
/* Increment the thread counter. */
|
||||||
thread_1_counter++;
|
thread_1_counter++;
|
||||||
|
|
||||||
@@ -192,13 +236,15 @@ void thread_1_entry(ULONG thread_input) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void thread_2_entry(ULONG thread_input) {
|
void thread_2_entry(ULONG thread_input)
|
||||||
|
{
|
||||||
|
|
||||||
ULONG received_message;
|
ULONG received_message;
|
||||||
UINT status;
|
UINT status;
|
||||||
|
|
||||||
/* This thread retrieves messages placed on the queue by thread 1. */
|
/* This thread retrieves messages placed on the queue by thread 1. */
|
||||||
while(1) {
|
while (1)
|
||||||
|
{
|
||||||
/* Increment the thread counter. */
|
/* Increment the thread counter. */
|
||||||
thread_2_counter++;
|
thread_2_counter++;
|
||||||
|
|
||||||
@@ -216,13 +262,15 @@ void thread_2_entry(ULONG thread_input) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void thread_3_and_4_entry(ULONG thread_input) {
|
void thread_3_and_4_entry(ULONG thread_input)
|
||||||
|
{
|
||||||
|
|
||||||
UINT status;
|
UINT status;
|
||||||
|
|
||||||
/* This function is executed from thread 3 and thread 4. As the loop
|
/* This function is executed from thread 3 and thread 4. As the loop
|
||||||
below shows, these function compete for ownership of semaphore_0. */
|
below shows, these function compete for ownership of semaphore_0. */
|
||||||
while(1) {
|
while (1)
|
||||||
|
{
|
||||||
puts("[Thread] : thread_3_and_4_entry is here!");
|
puts("[Thread] : thread_3_and_4_entry is here!");
|
||||||
|
|
||||||
/* Increment the thread counter. */
|
/* Increment the thread counter. */
|
||||||
@@ -250,13 +298,15 @@ void thread_3_and_4_entry(ULONG thread_input) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void thread_5_entry(ULONG thread_input) {
|
void thread_5_entry(ULONG thread_input)
|
||||||
|
{
|
||||||
|
|
||||||
UINT status;
|
UINT status;
|
||||||
ULONG actual_flags;
|
ULONG actual_flags;
|
||||||
|
|
||||||
/* This thread simply waits for an event in a forever loop. */
|
/* This thread simply waits for an event in a forever loop. */
|
||||||
while(1) {
|
while (1)
|
||||||
|
{
|
||||||
puts("[Thread] : thread_5_entry is here!");
|
puts("[Thread] : thread_5_entry is here!");
|
||||||
/* Increment the thread counter. */
|
/* Increment the thread counter. */
|
||||||
thread_5_counter++;
|
thread_5_counter++;
|
||||||
@@ -270,13 +320,15 @@ void thread_5_entry(ULONG thread_input) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void thread_6_and_7_entry(ULONG thread_input) {
|
void thread_6_and_7_entry(ULONG thread_input)
|
||||||
|
{
|
||||||
|
|
||||||
UINT status;
|
UINT status;
|
||||||
|
|
||||||
/* This function is executed from thread 6 and thread 7. As the loop
|
/* This function is executed from thread 6 and thread 7. As the loop
|
||||||
below shows, these function compete for ownership of mutex_0. */
|
below shows, these function compete for ownership of mutex_0. */
|
||||||
while(1) {
|
while (1)
|
||||||
|
{
|
||||||
puts("[Thread] : thread_6_and_7_entry is here!");
|
puts("[Thread] : thread_6_and_7_entry is here!");
|
||||||
/* Increment the thread counter. */
|
/* Increment the thread counter. */
|
||||||
if (thread_input == 6)
|
if (thread_input == 6)
|
||||||
|
|||||||
Reference in New Issue
Block a user