diff options
Diffstat (limited to 'debian/patches/fix-toolchain-insanity.diff')
-rw-r--r-- | debian/patches/fix-toolchain-insanity.diff | 289 |
1 files changed, 0 insertions, 289 deletions
diff --git a/debian/patches/fix-toolchain-insanity.diff b/debian/patches/fix-toolchain-insanity.diff deleted file mode 100644 index 9bc7fadf..00000000 --- a/debian/patches/fix-toolchain-insanity.diff +++ /dev/null @@ -1,289 +0,0 @@ -diff --git a/src/aes/ao_aes.c b/src/aes/ao_aes.c -index a04174c6..fd90c5bf 100644 ---- a/src/aes/ao_aes.c -+++ b/src/aes/ao_aes.c -@@ -359,10 +359,10 @@ void xrijndaelDecrypt(word32 block[], roundkey *rkk) - #endif - - uint8_t ao_aes_mutex; --static uint8_t key[16]; -+static word32 key[16/4]; - static roundkey rkk; - --static uint8_t iv[16]; -+static word32 iv[16/4]; - - void - ao_aes_set_mode(enum ao_aes_mode mode) -@@ -389,10 +389,11 @@ ao_aes_run(__xdata uint8_t *in, - __xdata uint8_t *out) - { - uint8_t i; -+ uint8_t *_iv = (uint8_t *) iv; - - for (i = 0; i < 16; i++) -- iv[i] ^= in[i]; -- xrijndaelEncrypt((word32 *) iv, &rkk); -+ _iv[i] ^= in[i]; -+ xrijndaelEncrypt(iv, &rkk); - if (out) - memcpy(out, iv, 16); - } -diff --git a/src/drivers/ao_gps_ublox.c b/src/drivers/ao_gps_ublox.c -index 22af413a..c720f802 100644 ---- a/src/drivers/ao_gps_ublox.c -+++ b/src/drivers/ao_gps_ublox.c -@@ -156,7 +156,7 @@ static char __xdata *ublox_target; - - static void ublox_u16(uint8_t offset) - { -- uint16_t __xdata *ptr = (uint16_t __xdata *) (ublox_target + offset); -+ uint16_t __xdata *ptr = (uint16_t __xdata *) (void __xdata *) (ublox_target + offset); - uint16_t val; - - val = data_byte(); -@@ -175,7 +175,7 @@ static void ublox_u8(uint8_t offset) - - static void ublox_u32(uint8_t offset) __reentrant - { -- uint32_t __xdata *ptr = (uint32_t __xdata *) (ublox_target + offset); -+ uint32_t __xdata *ptr = (uint32_t __xdata *) (void __xdata *) (ublox_target + offset); - uint32_t val; - - val = ((uint32_t) data_byte ()); -diff --git a/src/drivers/ao_trng_send.c b/src/drivers/ao_trng_send.c -index 85034efd..b1227aaa 100644 ---- a/src/drivers/ao_trng_send.c -+++ b/src/drivers/ao_trng_send.c -@@ -104,7 +104,7 @@ ao_trng_get_cooked(uint16_t *buf) - { - uint16_t i; - uint16_t t; -- uint32_t *rnd = (uint32_t *) ao_adc_ring; -+ uint32_t *rnd = (uint32_t *) (void *) ao_adc_ring; - uint8_t mismatch = 0; - - t = ao_adc_get(AO_USB_IN_SIZE) >> 1; /* one 16-bit value per output byte */ -diff --git a/src/kernel/ao_list.h b/src/kernel/ao_list.h -index e2df6885..45a3df5b 100644 ---- a/src/kernel/ao_list.h -+++ b/src/kernel/ao_list.h -@@ -138,7 +138,7 @@ ao_list_is_empty(struct ao_list *head) - * @return A pointer to the data struct containing the list head. - */ - #define ao_container_of(ptr, type, member) \ -- ((type *)((char *)(ptr) - offsetof(type, member))) -+ ((type *)((void *) ((char *)(ptr) - offsetof(type, member)))) - - /** - * Alias of ao_container_of -diff --git a/src/kernel/ao_pyro.c b/src/kernel/ao_pyro.c -index c9920ab3..813e866a 100644 ---- a/src/kernel/ao_pyro.c -+++ b/src/kernel/ao_pyro.c -@@ -437,7 +437,7 @@ ao_pyro_show(void) - if (ao_pyro_values[v].flag & AO_PYRO_8_BIT_VALUE) - value = *((uint8_t *) ((char *) pyro + ao_pyro_values[v].offset)); - else -- value = *((int16_t *) ((char *) pyro + ao_pyro_values[v].offset)); -+ value = *((int16_t *) (void *) ((char *) pyro + ao_pyro_values[v].offset)); - printf ("%6d ", value); - } else { - printf (" "); -@@ -516,7 +516,7 @@ ao_pyro_set(void) - } else { - if (negative) - ao_cmd_lex_i = -ao_cmd_lex_i; -- *((int16_t *) ((char *) &pyro_tmp + ao_pyro_values[v].offset)) = ao_cmd_lex_i; -+ *((int16_t *) (void *) ((char *) &pyro_tmp + ao_pyro_values[v].offset)) = ao_cmd_lex_i; - } - } - } -diff --git a/src/kernel/ao_task.h b/src/kernel/ao_task.h -index f1dbd654..30b018ff 100644 ---- a/src/kernel/ao_task.h -+++ b/src/kernel/ao_task.h -@@ -26,6 +26,17 @@ - #define HAS_TASK_INFO 1 - #endif - -+/* arm stacks must be 32-bit aligned */ -+#ifdef __arm__ -+#define AO_STACK_ALIGNMENT __attribute__ ((aligned(4))) -+#endif -+#ifdef SDCC -+#define AO_STACK_ALIGNMENT -+#endif -+#ifdef __AVR__ -+#define AO_STACK_ALIGNMENT -+#endif -+ - /* An AltOS task */ - struct ao_task { - __xdata void *wchan; /* current wait channel (NULL if running) */ -@@ -37,7 +48,7 @@ struct ao_task { - struct ao_list queue; - struct ao_list alarm_queue; - #endif -- uint8_t stack[AO_STACK_SIZE]; /* saved stack */ -+ uint8_t stack[AO_STACK_SIZE] AO_STACK_ALIGNMENT; /* saved stack */ - #if HAS_SAMPLE_PROFILE - uint32_t ticks; - uint32_t yields; -diff --git a/src/stm/Makefile.defs b/src/stm/Makefile.defs -index c3d2707f..0ba86f5a 100644 ---- a/src/stm/Makefile.defs -+++ b/src/stm/Makefile.defs -@@ -27,7 +27,7 @@ LIBS=$(PDCLIB_LIBS_M3) -lgcc - WARN_FLAGS=-Wall -Wextra -Werror - - AO_CFLAGS=-I. -I../stm -I../kernel -I../drivers -I../math -I.. $(PDCLIB_INCLUDES) --STM_CFLAGS=-std=gnu99 -mlittle-endian -mcpu=cortex-m3 -mthumb \ -+STM_CFLAGS=-std=gnu99 -mlittle-endian -mcpu=cortex-m3 -mthumb -Wcast-align \ - -ffreestanding -nostdlib $(AO_CFLAGS) $(WARN_FLAGS) - - LDFLAGS=-L../stm -Wl,-Taltos.ld -diff --git a/src/stm/ao_arch_funcs.h b/src/stm/ao_arch_funcs.h -index 18ca20da..a9d0fa34 100644 ---- a/src/stm/ao_arch_funcs.h -+++ b/src/stm/ao_arch_funcs.h -@@ -375,7 +375,7 @@ ao_arch_irq_check(void) { - static inline void - ao_arch_init_stack(struct ao_task *task, void *start) - { -- uint32_t *sp = (uint32_t *) (task->stack + AO_STACK_SIZE); -+ uint32_t *sp = (uint32_t *) ((void*) task->stack + AO_STACK_SIZE); - uint32_t a = (uint32_t) start; - int i; - -@@ -413,16 +413,11 @@ static inline void ao_arch_save_stack(void) { - uint32_t *sp; - asm("mov %0,sp" : "=&r" (sp) ); - ao_cur_task->sp = (sp); -- if ((uint8_t *) sp < &ao_cur_task->stack[0]) -- ao_panic (AO_PANIC_STACK); - } - - static inline void ao_arch_restore_stack(void) { -- uint32_t sp; -- sp = (uint32_t) ao_cur_task->sp; -- - /* Switch stacks */ -- asm("mov sp, %0" : : "r" (sp) ); -+ asm("mov sp, %0" : : "r" (ao_cur_task->sp) ); - - /* Restore PRIMASK */ - asm("pop {r0}"); -diff --git a/src/stm/ao_eeprom_stm.c b/src/stm/ao_eeprom_stm.c -index 05f880b8..4f477122 100644 ---- a/src/stm/ao_eeprom_stm.c -+++ b/src/stm/ao_eeprom_stm.c -@@ -83,7 +83,7 @@ ao_intflash_write32(uint16_t pos, uint32_t w) - { - volatile uint32_t *addr; - -- addr = (uint32_t *) (stm_eeprom + pos); -+ addr = (uint32_t *) (void *) (stm_eeprom + pos); - - /* Write a word to a valid address in the data EEPROM */ - *addr = w; -@@ -96,7 +96,7 @@ ao_intflash_write8(uint16_t pos, uint8_t d) - uint32_t w, *addr, mask; - uint8_t shift; - -- addr = (uint32_t *) (stm_eeprom + (pos & ~3)); -+ addr = (uint32_t *) (void *) (stm_eeprom + (pos & ~3)); - - /* Compute word to be written */ - shift = (pos & 3) << 3; -diff --git a/src/stm/ao_usb_stm.c b/src/stm/ao_usb_stm.c -index f2b8ea94..9d72844e 100644 ---- a/src/stm/ao_usb_stm.c -+++ b/src/stm/ao_usb_stm.c -@@ -139,7 +139,7 @@ static inline uint32_t set_toggle(uint32_t current_value, - - static inline uint32_t *ao_usb_packet_buffer_addr(uint16_t sram_addr) - { -- return (uint32_t *) (stm_usb_sram + 2 * sram_addr); -+ return (uint32_t *) (((void *) ((uint8_t *) stm_usb_sram + 2 * sram_addr))); - } - - static inline uint32_t ao_usb_epr_stat_rx(uint32_t epr) { -diff --git a/src/stm/stm32l.h b/src/stm/stm32l.h -index 463125e2..be1e1d65 100644 ---- a/src/stm/stm32l.h -+++ b/src/stm/stm32l.h -@@ -1961,7 +1961,7 @@ union stm_usb_bdt { - - #define STM_USB_BDT_SIZE 8 - --extern uint8_t stm_usb_sram[]; -+extern uint8_t stm_usb_sram[] __attribute__ ((aligned(4))); - - struct stm_exti { - vuint32_t imr; -diff --git a/src/stmf0/Makefile-stmf0.defs b/src/stmf0/Makefile-stmf0.defs -index 4862f46e..f3296b69 100644 ---- a/src/stmf0/Makefile-stmf0.defs -+++ b/src/stmf0/Makefile-stmf0.defs -@@ -25,7 +25,7 @@ endif - ELFTOHEX=$(TOPDIR)/../ao-tools/ao-elftohex/ao-elftohex - CC=$(ARM_CC) - --WARN_FLAGS=-Wall -Wextra -Werror -+WARN_FLAGS=-Wall -Wextra -Werror -Wcast-align - - AO_CFLAGS=-I. -I$(TOPDIR)/stmf0 -I$(TOPDIR)/kernel -I$(TOPDIR)/drivers -I$(TOPDIR)/product -I$(TOPDIR) -I$(TOPDIR)/math $(PDCLIB_INCLUDES) - STMF0_CFLAGS=-std=gnu99 -mlittle-endian -mcpu=cortex-m0 -mthumb\ -diff --git a/src/stmf0/ao_adc_fast.h b/src/stmf0/ao_adc_fast.h -index b8b5e003..3f0b0547 100644 ---- a/src/stmf0/ao_adc_fast.h -+++ b/src/stmf0/ao_adc_fast.h -@@ -28,7 +28,7 @@ ao_adc_init(void); - /* Total ring size in samples */ - #define AO_ADC_RING_SIZE 256 - --extern uint16_t ao_adc_ring[AO_ADC_RING_SIZE]; -+extern uint16_t ao_adc_ring[AO_ADC_RING_SIZE] __attribute__((aligned(4))); - - #define ao_adc_ring_step(pos,inc) (((pos) + (inc)) & (AO_ADC_RING_SIZE - 1)) - -diff --git a/src/stmf0/ao_arch_funcs.h b/src/stmf0/ao_arch_funcs.h -index 8b6234c4..0cb0e43d 100644 ---- a/src/stmf0/ao_arch_funcs.h -+++ b/src/stmf0/ao_arch_funcs.h -@@ -355,7 +355,7 @@ ao_arch_memory_barrier() { - static inline void - ao_arch_init_stack(struct ao_task *task, void *start) - { -- uint32_t *sp = (uint32_t *) (task->stack + AO_STACK_SIZE); -+ uint32_t *sp = (uint32_t *) ((void *) task->stack + AO_STACK_SIZE); - uint32_t a = (uint32_t) start; - int i; - -diff --git a/src/stmf0/ao_usb_stm.c b/src/stmf0/ao_usb_stm.c -index cbedb996..652b3b6c 100644 ---- a/src/stmf0/ao_usb_stm.c -+++ b/src/stmf0/ao_usb_stm.c -@@ -185,7 +185,7 @@ static inline uint32_t set_toggle(uint32_t current_value, - - static inline uint16_t *ao_usb_packet_buffer_addr(uint16_t sram_addr) - { -- return (uint16_t *) (stm_usb_sram + sram_addr); -+ return (uint16_t *) (void *) (stm_usb_sram + sram_addr); - } - - static inline uint16_t ao_usb_packet_buffer_offset(uint16_t *addr) -diff --git a/src/stmf0/stm32f0.h b/src/stmf0/stm32f0.h -index 054200e0..bafa763a 100644 ---- a/src/stmf0/stm32f0.h -+++ b/src/stmf0/stm32f0.h -@@ -1996,7 +1996,7 @@ union stm_usb_bdt { - - #define STM_USB_BDT_SIZE 8 - --extern uint8_t stm_usb_sram[]; -+extern uint8_t stm_usb_sram[] __attribute__((aligned(4))); - - struct stm_exti { - vuint32_t imr; |