Zephyr API Documentation  2.7.0-rc2
A Scalable Open Source RTOS
main.c File Reference
#include <zephyr.h>
#include <ztest.h>
#include <irq.h>
#include <tc_util.h>
#include <sw_isr_table.h>
#include <interrupt_util.h>

Macros

#define ISR1_OFFSET   0
 
#define ISR2_OFFSET   1
 
#define ISR3_OFFSET   2
 
#define ISR4_OFFSET   3
 
#define ISR5_OFFSET   4
 
#define ISR6_OFFSET   5
 
#define TEST_NUM_IRQS   CONFIG_NUM_IRQS
 
#define TEST_IRQ_TABLE_SIZE
 
#define IRQ_LINE(offset)   (TEST_NUM_IRQS - ((offset) + 1))
 
#define TABLE_INDEX(offset)   (TEST_IRQ_TABLE_SIZE - ((offset) + 1))
 
#define TRIG_CHECK_SIZE   6
 
#define ISR3_ARG   0xb01dface
 
#define ISR4_ARG   0xca55e77e
 
#define ISR5_ARG   0xf0ccac1a
 
#define ISR6_ARG   0xba5eba11
 

Functions

void isr3 (const void *param)
 
void isr4 (const void *param)
 
void isr5 (const void *param)
 
void isr6 (const void *param)
 
__no_optimization int test_irq (int offset)
 
void test_build_time_direct_interrupt (void)
 test to validate direct interrupt More...
 
void test_build_time_interrupt (void)
 test to validate gen_isr_table and interrupt More...
 
void test_run_time_interrupt (void)
 test to validate gen_isr_table and dynamic interrupt More...
 
void test_main (void)
 

Variables

static volatile int trigger_check [6]
 

Macro Definition Documentation

◆ IRQ_LINE

#define IRQ_LINE (   offset)    (TEST_NUM_IRQS - ((offset) + 1))

◆ ISR1_OFFSET

#define ISR1_OFFSET   0

◆ ISR2_OFFSET

#define ISR2_OFFSET   1

◆ ISR3_ARG

#define ISR3_ARG   0xb01dface

◆ ISR3_OFFSET

#define ISR3_OFFSET   2

◆ ISR4_ARG

#define ISR4_ARG   0xca55e77e

◆ ISR4_OFFSET

#define ISR4_OFFSET   3

◆ ISR5_ARG

#define ISR5_ARG   0xf0ccac1a

◆ ISR5_OFFSET

#define ISR5_OFFSET   4

◆ ISR6_ARG

#define ISR6_ARG   0xba5eba11

◆ ISR6_OFFSET

#define ISR6_OFFSET   5

◆ TABLE_INDEX

#define TABLE_INDEX (   offset)    (TEST_IRQ_TABLE_SIZE - ((offset) + 1))

◆ TEST_IRQ_TABLE_SIZE

#define TEST_IRQ_TABLE_SIZE
Value:
#define CONFIG_NUM_IRQS
Definition: irq.h:88
#define TEST_NUM_IRQS
Definition: main.c:69
#define IRQ_TABLE_SIZE
Definition: sw_isr_table.h:73

◆ TEST_NUM_IRQS

#define TEST_NUM_IRQS   CONFIG_NUM_IRQS

◆ TRIG_CHECK_SIZE

#define TRIG_CHECK_SIZE   6

Function Documentation

◆ isr3()

void isr3 ( const void param)

◆ isr4()

void isr4 ( const void param)

◆ isr5()

void isr5 ( const void param)

◆ isr6()

void isr6 ( const void param)

◆ test_build_time_direct_interrupt()

void test_build_time_direct_interrupt ( void  )

test to validate direct interrupt

initialize two direct interrupt handler using IRQ_DIRECT_CONNECT api at build time. For ‘direct’ interrupts, address of handler function will be placed in the irq vector table. And each entry contains the pointer to isr and the corresponding parameters.

At the end according to architecture, we manually trigger the interrupt. And all irq handler should get called.

See also
IRQ_DIRECT_CONNECT(), irq_enable()

◆ test_build_time_interrupt()

void test_build_time_interrupt ( void  )

test to validate gen_isr_table and interrupt

initialize two normal interrupt handler using IRQ_CONNECT api at build time. For 'regular' interrupts, the address of the common software isr table is placed in the irq vector table, and software ISR table is an array of struct _isr_table_entry. And each entry contains the pointer to isr and the corresponding parameters.

At the end according to architecture, we manually trigger the interrupt. And all irq handler should get called.

See also
IRQ_CONNECT(), irq_enable()

◆ test_irq()

__no_optimization int test_irq ( int  offset)

◆ test_main()

void test_main ( void  )

◆ test_run_time_interrupt()

void test_run_time_interrupt ( void  )

test to validate gen_isr_table and dynamic interrupt

initialize two dynamic interrupt handler using irq_connect_dynamic api at run time. For dynamic interrupts, the address of the common software isr table is also placed in the irq vector table. Software ISR table is an array of struct _isr_table_entry. And each entry contains the pointer to isr and the corresponding parameters.

At the end according to architecture, we manually trigger the interrupt. And all irq handler should get called.

See also
irq_connect_dynamic(), irq_enable()

Variable Documentation

◆ trigger_check

volatile int trigger_check[6]
static