diff --git a/Makefile b/Makefile index 87827af..2440860 100644 --- a/Makefile +++ b/Makefile @@ -2,7 +2,7 @@ F_CPU = 16000000UL TARGET = main CC = avr-gcc -INCLUDES = -I. +INCLUDES = -I../../headers/ AVRGCC_MCU_TYPE = atmega328p AVRDUDE_MCU_TYPE = m328p diff --git a/headers/bitmanip.h b/headers/bitmanip.h new file mode 100644 index 0000000..0808aec --- /dev/null +++ b/headers/bitmanip.h @@ -0,0 +1,61 @@ +#ifndef BITMANIP_H +#define BITMANIP_H + +#include "utils.h" + +// Bit operations on registers +#define SET(register, bit) (register |= (1 << (bit))) +#define CLEAR(register, bit) (register &= ~(1 << (bit))) +#define TEST(register, bit) (register & (1 << (bit))) +#define TOGGLE(register, bit) (register ^= (1 << (bit))) + +// Get arguments from tuple-like definitions +#define ARG_1(v1, v2) v1 +#define ARG_2(v1, v2) v2 +#define GET_PORT(args) ARG_1 args +#define GET_BIT(args) ARG_2 args +// // version with "LED1 B, D1" without parenthesis +// #define ARG_1(v1, ...) v1 +// #define ARG_2(v1, v2, ...) v2 +// #define GET_PORT(...) ARG_1(__VA_ARGS__) +// #define GET_BIT(...) ARG_2(__VA_ARGS__) + +// Actions on elements +// #define SET_ELEM(...) SET(CONCAT(PORT, GET_PORT(__VA_ARGS__)), GET_BIT(__VA_ARGS__)) // version for "LED1 B, D1" without parenthesis +#define SET_ELEM(elem) SET(CONCAT(PORT, GET_PORT(elem)), GET_BIT(elem)) +#define CLEAR_ELEM(elem) CLEAR(CONCAT(PORT, GET_PORT(elem)), GET_BIT(elem)) +#define TEST_ELEM(elem) TEST(CONCAT(PORT, GET_PORT(elem)), GET_BIT(elem)) +#define TOGGLE_ELEM(elem) TOGGLE(CONCAT(PORT, GET_PORT(elem)), GET_BIT(elem)) + +#define MODE_OUTPUT(elem) SET(CONCAT(DDR, GET_PORT(elem)), GET_BIT(elem)) +#define MODE_INPUT(elem) CLEAR(CONCAT(DDR, GET_PORT(elem)), GET_BIT(elem)) +#define TOGGLE_PIN(elem) SET(CONCAT(PIN, GET_PORT(elem)), GET_BIT(elem)) +#define TEST_PIN(elem) (TEST(CONCAT(PIN, GET_PORT(elem)), GET_BIT(elem))) +#define IS_PIN_SET(elem) (TEST_PIN(elem) == 0) +#define IS_PIN_CLEAR(elem) (TEST_PIN(elem) == 1) +#define PULLUP_ON(elem) SET(CONCAT(PORT, GET_PORT(elem)), GET_BIT(elem)) +#define PULLUP_OFF(elem) CLEAR(CONCAT(PORT, GET_PORT(elem)), GET_BIT(elem)) + +// Bit definitions ( // ) +#define D1 0 // PB0 +#define D2 1 // PB1 +#define D3 2 // PB2 +#define D4 4 // PB4 +#define SW1 2 // PD2 +#define SW2 4 // PD4 +#define D5B 3 // PD3 +#define D5R 5 // PD5 +#define D5G 6 // PD6 + +// Elements (port, bit) +#define LED1 (B, D1) +#define LED2 (B, D2) +#define LED3 (B, D3) +#define LED4 (B, D4) +#define BUTTON1 (D, SW1) +#define BUTTON2 (D, SW2) +#define RGB5_BLUE (D, D5B) +#define RGB5_RED (D, D5R) +#define RGB5_GEEN (D, D5G) + +#endif // BITMANIP_H \ No newline at end of file diff --git a/headers/interrupt.h b/headers/interrupt.h new file mode 100644 index 0000000..9668ef7 --- /dev/null +++ b/headers/interrupt.h @@ -0,0 +1,8 @@ +#ifndef INTERRUPT_H +#define INTERRUPT_H + +// 7.3.1 : SREG – AVR Status Register +#define ENABLE_GLOBAL_INTERRUPT (1<= 'A' && (ch) <= 'Z') || ((ch) >= 'a' && (ch) <= 'z') ? ((ch) ^ (1 << 5)) : (ch)) + +// boolean +#define TRUE 1 +#define FALSE 0 + +#endif // UTILS_H \ No newline at end of file diff --git a/module05/ex00/Makefile b/module05/ex00/Makefile new file mode 100644 index 0000000..2e40cba --- /dev/null +++ b/module05/ex00/Makefile @@ -0,0 +1 @@ +include ../../Makefile \ No newline at end of file diff --git a/module05/ex00/header.h b/module05/ex00/header.h new file mode 100644 index 0000000..9d923f3 --- /dev/null +++ b/module05/ex00/header.h @@ -0,0 +1,23 @@ +#ifndef HEADER_H +#define HEADER_H + +#include +#include +#include + +#include "utils.h" +#include "bitmanip.h" +#include "interrupt.h" +#include "timer.h" +#include "usart.h" + +// +// PROTOTYPES +// +// main.c + +// +// MACROS +// + +#endif // HEADER_H \ No newline at end of file diff --git a/module05/ex00/main.c b/module05/ex00/main.c new file mode 100644 index 0000000..34d51a4 --- /dev/null +++ b/module05/ex00/main.c @@ -0,0 +1,6 @@ +#include "header.h" + +// description +int main() { + while(1); +}