X-Git-Url: http://cloudbase.mooo.com/gitweb/z180-stamp.git/blobdiff_plain/61b0cfe9df810db4fbca78e5f880d61c5063f324..f2175f495629af499e2bb950f1691ebc58569156:/include/common.h diff --git a/include/common.h b/include/common.h index e8879a6..10c4417 100644 --- a/include/common.h +++ b/include/common.h @@ -1,8 +1,31 @@ +/* + * (C) Copyright 2014 Leo C. + * + * SPDX-License-Identifier: GPL-2.0+ + */ + #ifndef COMMON_H #define COMMON_H #ifdef __AVR__ #include +#include +#include + +#define udelay(n) _delay_us(n) + +struct bits { + uint8_t b0:1; + uint8_t b1:1; + uint8_t b2:1; + uint8_t b3:1; + uint8_t b4:1; + uint8_t b5:1; + uint8_t b6:1; + uint8_t b7:1; +} __attribute__((__packed__)); + +#define SBIT(port,pin) ((*(volatile struct bits*)&port).b##pin) //TODO: // Known to work: 4.8.4, 4.9.1 @@ -17,9 +40,11 @@ #ifdef __FLASH #define FLASH __flash +#define MEMX __memx #else #define FLASH -#endif +#define MEMX +#endif #define stringify(s) tostring(s) #define tostring(s) #s @@ -27,6 +52,12 @@ #define FSTR(X) ((const FLASH char[]) { X } ) #define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0])) +#define MIN(a,b) ({ typeof (a) _a = (a); \ + typeof (b) _b = (b); \ + _a < _b ? _a : _b; }) +#define MAX(a,b) ({ typeof (a) _a = (a); \ + typeof (b) _b = (b); \ + _a > _b ? _a : _b; }) #ifdef __AVR__ #define Stat GPIOR0 @@ -34,16 +65,17 @@ extern volatile uint_least8_t Stat; #endif /* __AVR__ */ -#define S_10MS_TO (1<<0) -#define S_Z180_RUNNING (2<<0) +#define S_10MS_TO (1<<0) +#define S_MSG_PENDING (1<<1) +#define S_CON_PENDING (1<<2) -static inline +static inline void my_puts(const char *s) { fputs(s, stdout); } -static inline +static inline void my_puts_P(const char *s) { #ifdef __AVR__ @@ -54,4 +86,3 @@ void my_puts_P(const char *s) } #endif /* COMMON_H */ -