mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
cpu/avr8_common: clean up thread_arch.c
Use __AVR_HAVE_RAMP<D,X,Y,Y>__ and __AVR_HAVE_3_BYTE_PC__ provided by the compiler instead of custom macros.
This commit is contained in:
parent
24103ad58a
commit
21daf782a7
@ -34,21 +34,9 @@
|
|||||||
#include "board.h"
|
#include "board.h"
|
||||||
#include "macros/xtstr.h"
|
#include "macros/xtstr.h"
|
||||||
|
|
||||||
#define CHECK_EIND_REG FLASHEND > 0x1ffff
|
|
||||||
|
|
||||||
#if defined(DATAMEM_SIZE)
|
|
||||||
#define CHECK_RAMPZ_REG DATAMEM_SIZE > 0xffff || FLASHEND > 0xffff
|
|
||||||
#define CHECK_RAMPDXY_REG DATAMEM_SIZE > 0xffff
|
|
||||||
#else
|
|
||||||
#define CHECK_RAMPZ_REG FLASHEND > 0xffff
|
|
||||||
#define CHECK_RAMPDXY_REG 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if (CHECK_EIND_REG)
|
|
||||||
#ifndef __EIND__
|
#ifndef __EIND__
|
||||||
#define __EIND__ 0x3C
|
#define __EIND__ 0x3C
|
||||||
#endif
|
#endif
|
||||||
#endif
|
|
||||||
|
|
||||||
static void avr8_context_save(void);
|
static void avr8_context_save(void);
|
||||||
static void avr8_context_restore(void);
|
static void avr8_context_restore(void);
|
||||||
@ -109,7 +97,7 @@ char *thread_stack_init(thread_task_func_t task_func, void *arg,
|
|||||||
tmp_adress >>= 8;
|
tmp_adress >>= 8;
|
||||||
*stk = (uint8_t)(tmp_adress & (uint16_t)0x00ff);
|
*stk = (uint8_t)(tmp_adress & (uint16_t)0x00ff);
|
||||||
|
|
||||||
#if (CHECK_EIND_REG)
|
#if __AVR_3_BYTE_PC__
|
||||||
/* Devices with more than 128kb FLASH use a PC with more than 16bits, we
|
/* Devices with more than 128kb FLASH use a PC with more than 16bits, we
|
||||||
* set whole the top byte forcibly to 0 */
|
* set whole the top byte forcibly to 0 */
|
||||||
stk--;
|
stk--;
|
||||||
@ -124,7 +112,7 @@ char *thread_stack_init(thread_task_func_t task_func, void *arg,
|
|||||||
tmp_adress >>= 8;
|
tmp_adress >>= 8;
|
||||||
*stk = (uint8_t)(tmp_adress & (uint16_t)0x00ff);
|
*stk = (uint8_t)(tmp_adress & (uint16_t)0x00ff);
|
||||||
|
|
||||||
#if (CHECK_EIND_REG)
|
#if __AVR_3_BYTE_PC__
|
||||||
/* Devices with more than 128kb FLASH use a PC with more than 16bits, we
|
/* Devices with more than 128kb FLASH use a PC with more than 16bits, we
|
||||||
* set whole the top byte forcibly to 0 */
|
* set whole the top byte forcibly to 0 */
|
||||||
stk--;
|
stk--;
|
||||||
@ -139,21 +127,25 @@ char *thread_stack_init(thread_task_func_t task_func, void *arg,
|
|||||||
stk--;
|
stk--;
|
||||||
*stk = (uint8_t)0x80;
|
*stk = (uint8_t)0x80;
|
||||||
|
|
||||||
#if (CHECK_RAMPZ_REG)
|
#if __AVR_HAVE_RAMPZ__
|
||||||
stk--;
|
stk--;
|
||||||
*stk = (uint8_t)0x00; /* RAMPZ */
|
*stk = (uint8_t)0x00; /* RAMPZ */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (CHECK_RAMPDXY_REG)
|
#if __AVR_HAVE_RAMPY__
|
||||||
stk--;
|
stk--;
|
||||||
*stk = (uint8_t)0x00; /* RAMPY */
|
*stk = (uint8_t)0x00; /* RAMPY */
|
||||||
|
#endif
|
||||||
|
#if __AVR_HAVE_RAMPX__
|
||||||
stk--;
|
stk--;
|
||||||
*stk = (uint8_t)0x00; /* RAMPX */
|
*stk = (uint8_t)0x00; /* RAMPX */
|
||||||
|
#endif
|
||||||
|
#if __AVR_HAVE_RAMPD__
|
||||||
stk--;
|
stk--;
|
||||||
*stk = (uint8_t)0x00; /* RAMPD */
|
*stk = (uint8_t)0x00; /* RAMPD */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (CHECK_EIND_REG)
|
#if __AVR_3_BYTE_PC__
|
||||||
stk--;
|
stk--;
|
||||||
*stk = (uint8_t)0x00; /* EIND */
|
*stk = (uint8_t)0x00; /* EIND */
|
||||||
#endif
|
#endif
|
||||||
@ -302,21 +294,27 @@ __attribute__((always_inline)) static inline void avr8_context_save(void)
|
|||||||
"cli \n\t"
|
"cli \n\t"
|
||||||
"push __tmp_reg__ \n\t"
|
"push __tmp_reg__ \n\t"
|
||||||
|
|
||||||
#if (CHECK_RAMPZ_REG)
|
#if __AVR_HAVE_RAMPZ__
|
||||||
"in __tmp_reg__, __RAMPZ__ \n\t"
|
"in __tmp_reg__, __RAMPZ__ \n\t"
|
||||||
"push __tmp_reg__ \n\t"
|
"push __tmp_reg__ \n\t"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (CHECK_RAMPDXY_REG)
|
#if __AVR_HAVE_RAMPY__
|
||||||
"in __tmp_reg__, __RAMPY__ \n\t"
|
"in __tmp_reg__, __RAMPY__ \n\t"
|
||||||
"push __tmp_reg__ \n\t"
|
"push __tmp_reg__ \n\t"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __AVR_HAVE_RAMPX__
|
||||||
"in __tmp_reg__, __RAMPX__ \n\t"
|
"in __tmp_reg__, __RAMPX__ \n\t"
|
||||||
"push __tmp_reg__ \n\t"
|
"push __tmp_reg__ \n\t"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __AVR_HAVE_RAMPD__
|
||||||
"in __tmp_reg__, __RAMPD__ \n\t"
|
"in __tmp_reg__, __RAMPD__ \n\t"
|
||||||
"push __tmp_reg__ \n\t"
|
"push __tmp_reg__ \n\t"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (CHECK_EIND_REG)
|
#if __AVR_3_BYTE_PC__
|
||||||
"in __tmp_reg__, " XTSTR(__EIND__) " \n\t"
|
"in __tmp_reg__, " XTSTR(__EIND__) " \n\t"
|
||||||
"push __tmp_reg__ \n\t"
|
"push __tmp_reg__ \n\t"
|
||||||
#endif
|
#endif
|
||||||
@ -402,21 +400,25 @@ __attribute__((always_inline)) static inline void avr8_context_restore(void)
|
|||||||
"pop r2 \n\t"
|
"pop r2 \n\t"
|
||||||
"pop r1 \n\t"
|
"pop r1 \n\t"
|
||||||
|
|
||||||
#if (CHECK_EIND_REG)
|
#if __AVR_3_BYTE_PC__
|
||||||
"pop __tmp_reg__ \n\t"
|
"pop __tmp_reg__ \n\t"
|
||||||
"out " XTSTR(__EIND__) ", __tmp_reg__ \n\t"
|
"out " XTSTR(__EIND__) ", __tmp_reg__ \n\t"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (CHECK_RAMPDXY_REG)
|
#if __AVR_HAVE_RAMPD__
|
||||||
"pop __tmp_reg__ \n\t"
|
"pop __tmp_reg__ \n\t"
|
||||||
"out __RAMPD__, __tmp_reg__ \n\t"
|
"out __RAMPD__, __tmp_reg__ \n\t"
|
||||||
|
#endif
|
||||||
|
#if __AVR_HAVE_RAMPX__
|
||||||
"pop __tmp_reg__ \n\t"
|
"pop __tmp_reg__ \n\t"
|
||||||
"out __RAMPX__, __tmp_reg__ \n\t"
|
"out __RAMPX__, __tmp_reg__ \n\t"
|
||||||
|
#endif
|
||||||
|
#if __AVR_HAVE_RAMPY__
|
||||||
"pop __tmp_reg__ \n\t"
|
"pop __tmp_reg__ \n\t"
|
||||||
"out __RAMPY__, __tmp_reg__ \n\t"
|
"out __RAMPY__, __tmp_reg__ \n\t"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (CHECK_RAMPZ_REG)
|
#if __AVR_HAVE_RAMPZ__
|
||||||
"pop __tmp_reg__ \n\t"
|
"pop __tmp_reg__ \n\t"
|
||||||
"out __RAMPZ__, __tmp_reg__ \n\t"
|
"out __RAMPZ__, __tmp_reg__ \n\t"
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user