You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

191 lines
5.2 KiB
C

/* Board Support Package (BSP) for the EK-TM4C123GXL board */
#include "qpc.h"
#include "bsp.h"
#include "TM4C123GH6PM.h" /* the TM4C MCU Peripheral Access Layer (TI) */
/* on-board LEDs */
#define LED_RED (1U << 1)
#define LED_BLUE (1U << 2)
#define LED_GREEN (1U << 3)
/* on-board switch */
#define BTN_SW1 (1U << 4)
//SEMA
//static QXSemaphore Morse_sema;
//MUTEX
static QXMutex Morse_mutex;
void SysTick_Handler(void) {
QXK_ISR_ENTRY(); /* inform QXK about entering an ISR */
QF_TICK_X(0U, (void *)0); /* process time events for rate 0 */
QXK_ISR_EXIT(); /* inform QXK about exiting an ISR */
}
void GPIOPortF_IRQHandler(void) {
QXK_ISR_ENTRY(); /* inform QXK about entering an ISR */
if ((GPIOF_AHB->RIS & BTN_SW1) != 0U) { /* interrupt caused by SW1? */
QXSemaphore_signal(&SW1_sema);
}
GPIOF_AHB->ICR = 0xFFU; /* clear interrupt sources */
QXK_ISR_EXIT(); /* inform QXK about exiting an ISR */
}
void BSP_init(void) {
SYSCTL->RCGCGPIO |= (1U << 5); /* enable Run Mode for GPIOF */
SYSCTL->GPIOHBCTL |= (1U << 5); /* enable AHB for GPIOF */
/* make sure the Run Mode and AHB-enable take effects
* before accessing the peripherals
*/
__ISB(); /* Instruction Synchronization Barrier */
__DSB(); /* Data Memory Barrier */
GPIOF_AHB->DIR |= (LED_RED | LED_BLUE | LED_GREEN);
GPIOF_AHB->DEN |= (LED_RED | LED_BLUE | LED_GREEN);
/* configure switch SW1 */
GPIOF_AHB->DIR &= ~BTN_SW1; /* input */
GPIOF_AHB->DEN |= BTN_SW1; /* digital enable */
GPIOF_AHB->PUR |= BTN_SW1; /* pull-up resistor enable */
/* GPIO interrupt setup for SW1 */
GPIOF_AHB->IS &= ~BTN_SW1; /* edge detect for SW1 */
GPIOF_AHB->IBE &= ~BTN_SW1; /* only one edge generate the interrupt */
GPIOF_AHB->IEV &= ~BTN_SW1; /* a falling edge triggers the interrupt */
GPIOF_AHB->IM |= BTN_SW1; /* enable GPIOF interrupt for SW1 */
//SEMA
///* initialize the Morse_sema semaphore as binary, resource semaphore */
//QXSemaphore_init(&Morse_sema, /* pointer to semaphore to initialize */
// 1U, /* initial semaphore count (resource semaphore) */
// 1U); /* maximum semaphore count (binary semaphore) */
//MUTEX
QXMutex_init(&Morse_mutex, 6U); /* priority ceiling 6 */
}
void BSP_ledRedOn(void) {
GPIOF_AHB->DATA_Bits[LED_RED] = LED_RED;
}
void BSP_ledRedOff(void) {
GPIOF_AHB->DATA_Bits[LED_RED] = 0U;
}
void BSP_ledBlueOn(void) {
GPIOF_AHB->DATA_Bits[LED_BLUE] = LED_BLUE;
}
void BSP_ledBlueOff(void) {
GPIOF_AHB->DATA_Bits[LED_BLUE] = 0U;
}
void BSP_ledBlueToggle(void) {
//CRIT
QF_CRIT_STAT
QF_CRIT_ENTRY();
GPIOF_AHB->DATA ^= LED_BLUE;
QF_CRIT_EXIT();
}
void BSP_ledGreenOn(void) {
GPIOF_AHB->DATA_Bits[LED_GREEN] = LED_GREEN;
}
void BSP_ledGreenOff(void) {
GPIOF_AHB->DATA_Bits[LED_GREEN] = 0U;
}
void BSP_ledGreenToggle(void) {
//CRIT
QF_CRIT_STAT
QF_CRIT_ENTRY();
GPIOF_AHB->DATA ^= LED_GREEN;
QF_CRIT_EXIT();
}
void BSP_sendMorseCode(uint32_t bitmask) {
uint32_t volatile delay_ctr;
enum { DOT_DELAY = 150 };
//LOCK
//QSchedStatus sstat;
//SEMA
//QXSemaphore_wait(&Morse_sema, /* pointer to semaphore to wait on */
// QXTHREAD_NO_TIMEOUT); /* timeout for waiting */
//LOCK
//sstat = QXK_schedLock(5U); /* priority ceiling 5 */
//MUTEX
QXMutex_lock(&Morse_mutex,
QXTHREAD_NO_TIMEOUT); /* timeout for waiting */
for (; bitmask != 0U; bitmask <<= 1) {
if ((bitmask & (1U << 31)) != 0U) {
BSP_ledGreenOn();
}
else {
BSP_ledGreenOff();
}
for (delay_ctr = DOT_DELAY;
delay_ctr != 0U; --delay_ctr) {
}
}
BSP_ledGreenOff();
for (delay_ctr = 7*DOT_DELAY;
delay_ctr != 0U; --delay_ctr) {
}
//SEMA
//QXSemaphore_signal(&Morse_sema); /* pointer to semaphore to signal */
//LOCK
//QXK_schedUnlock(sstat);
//MUTEX
QXMutex_unlock(&Morse_mutex);
}
/* callbacks ---------------------------------------------------------------*/
void QF_onStartup(void) {
SystemCoreClockUpdate();
SysTick_Config(SystemCoreClock / BSP_TICKS_PER_SEC);
/* set the interrupt priorities of "kernel aware" interrupts */
NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI);
NVIC_SetPriority(GPIOF_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1);
/* enable IRQs in NVIC... */
NVIC_EnableIRQ(GPIOF_IRQn);
}
/*..........................................................................*/
void QF_onCleanup(void) {
}
void QXK_onIdle(void) {
GPIOF_AHB->DATA_Bits[LED_RED] = LED_RED;
GPIOF_AHB->DATA_Bits[LED_RED] = 0U;
//__WFI(); /* stop the CPU and Wait for Interrupt */
}
void Q_onAssert(char const *module, int loc) {
/* TBD: damage control */
(void)module; /* avoid the "unused parameter" compiler warning */
(void)loc; /* avoid the "unused parameter" compiler warning */
NVIC_SystemReset();
}
//............................................................................
_Noreturn void assert_failed(char const * const module, int const id);
_Noreturn void assert_failed(char const * const module, int const id) {
Q_onAssert(module, id);
}