4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-26 05:57:23 +08:00

253 lines
5.7 KiB
C
Raw Normal View History

/*
* Copyright (c) 2006-2022, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
2021-03-27 15:16:57 +08:00
* Date Author Notes
* 2012-02-21 onelife Initial creation for EFM32
*/
2013-01-08 22:40:58 +08:00
/***************************************************************************//**
* @addtogroup efm32
* @{
******************************************************************************/
/* Includes ------------------------------------------------------------------*/
#include "board.h"
#include "drv_emu.h"
/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
/* Private macro -------------------------------------------------------------*/
#ifdef EFM32_EMU_DEBUG
2021-03-27 15:16:57 +08:00
#define emu_debug(format,args...) rt_kprintf(format, ##args)
2013-01-08 22:40:58 +08:00
#else
#define emu_debug(format,args...)
#endif
/* Private variables ---------------------------------------------------------*/
struct efm32_emu_task emu_task;
/***************************************************************************//**
* @brief
* Register SPI device
*
* @details
*
* @note
*
* @param[in] device
* Pointer to device descriptor
*
* @param[in] name
* Device name
*
* @param[in] flag
* Configuration flags
*
* @param[in] spi
* Pointer to SPI device descriptor
*
* @return
* Error code
******************************************************************************/
void emu_task_main_loop(void *parameter)
{
struct efm32_emu_task *emu_task = (struct efm32_emu_task *)parameter;
while(1)
{
if (emu_task->em2.value == EMU_TASK_EM2_TOKEN_NUMBER)
{
if (emu_task->em3.value == EMU_TASK_EM3_TOKEN_NUMBER)
{
if (emu_task->em4.value == EMU_TASK_EM4_TOKEN_NUMBER)
{
EMU_EnterEM4();
}
else
{
EMU_EnterEM3(RT_TRUE);
}
}
else
{
EMU_EnterEM2(RT_TRUE);
}
}
else
{
EMU_EnterEM1();
}
}
}
#define OS_TIMER_LIST_EMPTY (0x00000001)
#define OS_TIMER_LIST_NOT_EMPTY (0x00000002)
void emu_event_send(rt_uint32_t event)
{
switch (event)
{
case OS_TIMER_LIST_EMPTY:
// SysTick->CTRL &= ~SysTick_CTRL_CLKSOURCE_Msk;
break;
case OS_TIMER_LIST_NOT_EMPTY:
// SysTick->CTRL |= SysTick_CTRL_CLKSOURCE_Msk;
break;
}
}
rt_bool_t emu_is_emu(struct rt_thread *thread)
{
return (thread == &emu_task.thread);
}
void emu_all_disable(void)
{
if (rt_sem_take(&emu_task.em4, RT_WAITING_NO) != RT_EOK)
{
RT_ASSERT(0);
}
if (rt_sem_take(&emu_task.em3, RT_WAITING_NO) != RT_EOK)
{
RT_ASSERT(0);
}
if (rt_sem_take(&emu_task.em2, RT_WAITING_NO) != RT_EOK)
{
RT_ASSERT(0);
}
}
void emu_em2_disable(void)
{
if (rt_sem_take(&emu_task.em2, RT_WAITING_NO) != RT_EOK)
{
RT_ASSERT(0);
}
}
void emu_em2_enable(void)
{
if (rt_sem_release(&emu_task.em2) != RT_EOK)
{
RT_ASSERT(0);
}
}
void emu_em3_disable(void)
{
if (rt_sem_take(&emu_task.em3, RT_WAITING_NO) != RT_EOK)
{
RT_ASSERT(0);
}
}
void emu_em3_enable(void)
{
if (rt_sem_release(&emu_task.em3) != RT_EOK)
{
RT_ASSERT(0);
}
}
void emu_em4_disable(void)
{
if (rt_sem_take(&emu_task.em4, RT_WAITING_NO) != RT_EOK)
{
RT_ASSERT(0);
}
}
void emu_em4_enable(void)
{
if (rt_sem_release(&emu_task.em4) != RT_EOK)
{
RT_ASSERT(0);
}
}
/***************************************************************************//**
* @brief
2021-03-27 15:16:57 +08:00
* Initialize EMU module related hardware
2013-01-08 22:40:58 +08:00
*
* @details
*
* @note
*
******************************************************************************/
void efm32_emu_init(void)
{
do
{
/* init token */
if (rt_sem_init(
&emu_task.em2,
"EM2",
EMU_TASK_EM2_TOKEN_NUMBER,
RT_IPC_FLAG_FIFO) != RT_EOK)
{
break;
}
if (rt_sem_init(
&emu_task.em3,
"EM3",
EMU_TASK_EM3_TOKEN_NUMBER,
RT_IPC_FLAG_FIFO) != RT_EOK)
{
break;
}
if (rt_sem_init(
&emu_task.em4,
"EM4",
EMU_TASK_EM4_TOKEN_NUMBER,
RT_IPC_FLAG_FIFO) != RT_EOK)
{
break;
}
2021-03-27 15:16:57 +08:00
/* init thread */
2013-01-08 22:40:58 +08:00
if (rt_thread_init(
&emu_task.thread,
"EMU",
2021-03-27 15:16:57 +08:00
emu_task_main_loop, (void *)&emu_task,
2013-01-08 22:40:58 +08:00
(void *)&emu_task.stack, sizeof(emu_task.stack),
2021-03-27 15:16:57 +08:00
RT_THREAD_PRIORITY_MAX - 2, RT_TICK_PER_SECOND) != RT_EOK)
2013-01-08 22:40:58 +08:00
{
break;
}
2021-03-27 15:16:57 +08:00
/* startup */
if (rt_thread_startup(&emu_task.thread) != RT_EOK)
{
2013-01-08 22:40:58 +08:00
break;
2021-03-27 15:16:57 +08:00
}
2013-01-08 22:40:58 +08:00
} while (0);
rt_kprintf("EMU err: init failed!\n");
}
/*******************************************************************************
* Export to FINSH
******************************************************************************/
#ifdef RT_USING_FINSH
#include <finsh.h>
void list_emu(void)
{
rt_kprintf(" --------- EMU Status ---------\n");
rt_kprintf(" em2 token used %d\n",
EMU_TASK_EM2_TOKEN_NUMBER - emu_task.em2.value);
rt_kprintf(" em3 token used %d\n",
EMU_TASK_EM3_TOKEN_NUMBER - emu_task.em3.value);
rt_kprintf(" em4 token used %d\n",
EMU_TASK_EM4_TOKEN_NUMBER - emu_task.em4.value);
}
FINSH_FUNCTION_EXPORT(list_emu, list the EMU status)
#endif
/***************************************************************************//**
* @}
******************************************************************************/