1
0
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:
Marian Buschsieweke 2022-06-20 19:41:32 +02:00
parent 24103ad58a
commit 21daf782a7
No known key found for this signature in database
GPG Key ID: CB8E3238CE715A94

View File

@ -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