diff options
Diffstat (limited to 'platforms')
28 files changed, 379 insertions, 1070 deletions
| diff --git a/platforms/arm_atsam/pin_defs.h b/platforms/arm_atsam/_pin_defs.h index 5b50b23910..5b50b23910 100644 --- a/platforms/arm_atsam/pin_defs.h +++ b/platforms/arm_atsam/_pin_defs.h diff --git a/platforms/avr/pin_defs.h b/platforms/avr/_pin_defs.h index 3889704a87..3889704a87 100644 --- a/platforms/avr/pin_defs.h +++ b/platforms/avr/_pin_defs.h diff --git a/platforms/avr/drivers/hd44780.c b/platforms/avr/drivers/hd44780.c deleted file mode 100644 index f15d7d0da8..0000000000 --- a/platforms/avr/drivers/hd44780.c +++ /dev/null @@ -1,542 +0,0 @@ -/**************************************************************************** - Title:     HD44780U LCD library - Author:    Peter Fleury <pfleury@gmx.ch>  http://tinyurl.com/peterfleury - License:   GNU General Public License Version 3 - File:	    $Id: lcd.c,v 1.15.2.2 2015/01/17 12:16:05 peter Exp $ - Software:  AVR-GCC 3.3 - Target:    any AVR device, memory mapped mode only for AT90S4414/8515/Mega - - DESCRIPTION -       Basic routines for interfacing a HD44780U-based text lcd display - -       Originally based on Volker Oth's lcd library, -       changed lcd_init(), added additional constants for lcd_command(), -       added 4-bit I/O mode, improved and optimized code. - -       Library can be operated in memory mapped mode (LCD_IO_MODE=0) or in -       4-bit IO port mode (LCD_IO_MODE=1). 8-bit IO port mode not supported. - -       Memory mapped mode compatible with Kanda STK200, but supports also -       generation of R/W signal through A8 address line. - - USAGE -       See the C include lcd.h file for a description of each function - -*****************************************************************************/ -#include <inttypes.h> -#include <avr/io.h> -#include <avr/pgmspace.h> -#include <util/delay.h> -#include "hd44780.h" - -/* -** constants/macros -*/ -#define DDR(x) (*(&x - 1)) /* address of data direction register of port x */ -#if defined(__AVR_ATmega64__) || defined(__AVR_ATmega128__) -/* on ATmega64/128 PINF is on port 0x00 and not 0x60 */ -#    define PIN(x) (&PORTF == &(x) ? _SFR_IO8(0x00) : (*(&x - 2))) -#else -#    define PIN(x) (*(&x - 2)) /* address of input register of port x          */ -#endif - -#if LCD_IO_MODE -#    define lcd_e_delay() _delay_us(LCD_DELAY_ENABLE_PULSE) -#    define lcd_e_high() LCD_E_PORT |= _BV(LCD_E_PIN); -#    define lcd_e_low() LCD_E_PORT &= ~_BV(LCD_E_PIN); -#    define lcd_e_toggle() toggle_e() -#    define lcd_rw_high() LCD_RW_PORT |= _BV(LCD_RW_PIN) -#    define lcd_rw_low() LCD_RW_PORT &= ~_BV(LCD_RW_PIN) -#    define lcd_rs_high() LCD_RS_PORT |= _BV(LCD_RS_PIN) -#    define lcd_rs_low() LCD_RS_PORT &= ~_BV(LCD_RS_PIN) -#endif - -#if LCD_IO_MODE -#    if LCD_LINES == 1 -#        define LCD_FUNCTION_DEFAULT LCD_FUNCTION_4BIT_1LINE -#    else -#        define LCD_FUNCTION_DEFAULT LCD_FUNCTION_4BIT_2LINES -#    endif -#else -#    if LCD_LINES == 1 -#        define LCD_FUNCTION_DEFAULT LCD_FUNCTION_8BIT_1LINE -#    else -#        define LCD_FUNCTION_DEFAULT LCD_FUNCTION_8BIT_2LINES -#    endif -#endif - -#if LCD_CONTROLLER_KS0073 -#    if LCD_LINES == 4 - -#        define KS0073_EXTENDED_FUNCTION_REGISTER_ON 0x2C  /* |0|010|1100 4-bit mode, extension-bit RE = 1 */ -#        define KS0073_EXTENDED_FUNCTION_REGISTER_OFF 0x28 /* |0|010|1000 4-bit mode, extension-bit RE = 0 */ -#        define KS0073_4LINES_MODE 0x09                    /* |0|000|1001 4 lines mode */ - -#    endif -#endif - -/* -** function prototypes -*/ -#if LCD_IO_MODE -static void toggle_e(void); -#endif - -/* -** local functions -*/ - -/************************************************************************* -delay for a minimum of <us> microseconds -the number of loops is calculated at compile-time from MCU clock frequency -*************************************************************************/ -#define delay(us) _delay_us(us) - -#if LCD_IO_MODE -/* toggle Enable Pin to initiate write */ -static void toggle_e(void) { -    lcd_e_high(); -    lcd_e_delay(); -    lcd_e_low(); -} -#endif - -/************************************************************************* -Low-level function to write byte to LCD controller -Input:    data   byte to write to LCD -          rs     1: write data -                 0: write instruction -Returns:  none -*************************************************************************/ -#if LCD_IO_MODE -static void lcd_write(uint8_t data, uint8_t rs) { -    unsigned char dataBits; - -    if (rs) { /* write data        (RS=1, RW=0) */ -        lcd_rs_high(); -    } else { /* write instruction (RS=0, RW=0) */ -        lcd_rs_low(); -    } -    lcd_rw_low(); /* RW=0  write mode      */ - -    if ((&LCD_DATA0_PORT == &LCD_DATA1_PORT) && (&LCD_DATA1_PORT == &LCD_DATA2_PORT) && (&LCD_DATA2_PORT == &LCD_DATA3_PORT) && (LCD_DATA0_PIN == 0) && (LCD_DATA1_PIN == 1) && (LCD_DATA2_PIN == 2) && (LCD_DATA3_PIN == 3)) { -        /* configure data pins as output */ -        DDR(LCD_DATA0_PORT) |= 0x0F; - -        /* output high nibble first */ -        dataBits       = LCD_DATA0_PORT & 0xF0; -        LCD_DATA0_PORT = dataBits | ((data >> 4) & 0x0F); -        lcd_e_toggle(); - -        /* output low nibble */ -        LCD_DATA0_PORT = dataBits | (data & 0x0F); -        lcd_e_toggle(); - -        /* all data pins high (inactive) */ -        LCD_DATA0_PORT = dataBits | 0x0F; -    } else { -        /* configure data pins as output */ -        DDR(LCD_DATA0_PORT) |= _BV(LCD_DATA0_PIN); -        DDR(LCD_DATA1_PORT) |= _BV(LCD_DATA1_PIN); -        DDR(LCD_DATA2_PORT) |= _BV(LCD_DATA2_PIN); -        DDR(LCD_DATA3_PORT) |= _BV(LCD_DATA3_PIN); - -        /* output high nibble first */ -        LCD_DATA3_PORT &= ~_BV(LCD_DATA3_PIN); -        LCD_DATA2_PORT &= ~_BV(LCD_DATA2_PIN); -        LCD_DATA1_PORT &= ~_BV(LCD_DATA1_PIN); -        LCD_DATA0_PORT &= ~_BV(LCD_DATA0_PIN); -        if (data & 0x80) LCD_DATA3_PORT |= _BV(LCD_DATA3_PIN); -        if (data & 0x40) LCD_DATA2_PORT |= _BV(LCD_DATA2_PIN); -        if (data & 0x20) LCD_DATA1_PORT |= _BV(LCD_DATA1_PIN); -        if (data & 0x10) LCD_DATA0_PORT |= _BV(LCD_DATA0_PIN); -        lcd_e_toggle(); - -        /* output low nibble */ -        LCD_DATA3_PORT &= ~_BV(LCD_DATA3_PIN); -        LCD_DATA2_PORT &= ~_BV(LCD_DATA2_PIN); -        LCD_DATA1_PORT &= ~_BV(LCD_DATA1_PIN); -        LCD_DATA0_PORT &= ~_BV(LCD_DATA0_PIN); -        if (data & 0x08) LCD_DATA3_PORT |= _BV(LCD_DATA3_PIN); -        if (data & 0x04) LCD_DATA2_PORT |= _BV(LCD_DATA2_PIN); -        if (data & 0x02) LCD_DATA1_PORT |= _BV(LCD_DATA1_PIN); -        if (data & 0x01) LCD_DATA0_PORT |= _BV(LCD_DATA0_PIN); -        lcd_e_toggle(); - -        /* all data pins high (inactive) */ -        LCD_DATA0_PORT |= _BV(LCD_DATA0_PIN); -        LCD_DATA1_PORT |= _BV(LCD_DATA1_PIN); -        LCD_DATA2_PORT |= _BV(LCD_DATA2_PIN); -        LCD_DATA3_PORT |= _BV(LCD_DATA3_PIN); -    } -} -#else -#    define lcd_write(d, rs)                        \ -        if (rs)                                     \ -            *(volatile uint8_t *)(LCD_IO_DATA) = d; \ -        else                                        \ -            *(volatile uint8_t *)(LCD_IO_FUNCTION) = d; -/* rs==0 -> write instruction to LCD_IO_FUNCTION */ -/* rs==1 -> write data to LCD_IO_DATA */ -#endif - -/************************************************************************* -Low-level function to read byte from LCD controller -Input:    rs     1: read data -                 0: read busy flag / address counter -Returns:  byte read from LCD controller -*************************************************************************/ -#if LCD_IO_MODE -static uint8_t lcd_read(uint8_t rs) { -    uint8_t data; - -    if (rs) -        lcd_rs_high(); /* RS=1: read data      */ -    else -        lcd_rs_low(); /* RS=0: read busy flag */ -    lcd_rw_high();    /* RW=1  read mode      */ - -    if ((&LCD_DATA0_PORT == &LCD_DATA1_PORT) && (&LCD_DATA1_PORT == &LCD_DATA2_PORT) && (&LCD_DATA2_PORT == &LCD_DATA3_PORT) && (LCD_DATA0_PIN == 0) && (LCD_DATA1_PIN == 1) && (LCD_DATA2_PIN == 2) && (LCD_DATA3_PIN == 3)) { -        DDR(LCD_DATA0_PORT) &= 0xF0; /* configure data pins as input */ - -        lcd_e_high(); -        lcd_e_delay(); -        data = PIN(LCD_DATA0_PORT) << 4; /* read high nibble first */ -        lcd_e_low(); - -        lcd_e_delay(); /* Enable 500ns low       */ - -        lcd_e_high(); -        lcd_e_delay(); -        data |= PIN(LCD_DATA0_PORT) & 0x0F; /* read low nibble        */ -        lcd_e_low(); -    } else { -        /* configure data pins as input */ -        DDR(LCD_DATA0_PORT) &= ~_BV(LCD_DATA0_PIN); -        DDR(LCD_DATA1_PORT) &= ~_BV(LCD_DATA1_PIN); -        DDR(LCD_DATA2_PORT) &= ~_BV(LCD_DATA2_PIN); -        DDR(LCD_DATA3_PORT) &= ~_BV(LCD_DATA3_PIN); - -        /* read high nibble first */ -        lcd_e_high(); -        lcd_e_delay(); -        data = 0; -        if (PIN(LCD_DATA0_PORT) & _BV(LCD_DATA0_PIN)) data |= 0x10; -        if (PIN(LCD_DATA1_PORT) & _BV(LCD_DATA1_PIN)) data |= 0x20; -        if (PIN(LCD_DATA2_PORT) & _BV(LCD_DATA2_PIN)) data |= 0x40; -        if (PIN(LCD_DATA3_PORT) & _BV(LCD_DATA3_PIN)) data |= 0x80; -        lcd_e_low(); - -        lcd_e_delay(); /* Enable 500ns low       */ - -        /* read low nibble */ -        lcd_e_high(); -        lcd_e_delay(); -        if (PIN(LCD_DATA0_PORT) & _BV(LCD_DATA0_PIN)) data |= 0x01; -        if (PIN(LCD_DATA1_PORT) & _BV(LCD_DATA1_PIN)) data |= 0x02; -        if (PIN(LCD_DATA2_PORT) & _BV(LCD_DATA2_PIN)) data |= 0x04; -        if (PIN(LCD_DATA3_PORT) & _BV(LCD_DATA3_PIN)) data |= 0x08; -        lcd_e_low(); -    } -    return data; -} -#else -#    define lcd_read(rs) (rs) ? *(volatile uint8_t *)(LCD_IO_DATA + LCD_IO_READ) : *(volatile uint8_t *)(LCD_IO_FUNCTION + LCD_IO_READ) -/* rs==0 -> read instruction from LCD_IO_FUNCTION */ -/* rs==1 -> read data from LCD_IO_DATA */ -#endif - -/************************************************************************* -loops while lcd is busy, returns address counter -*************************************************************************/ -static uint8_t lcd_waitbusy(void) - -{ -    register uint8_t c; - -    /* wait until busy flag is cleared */ -    while ((c = lcd_read(0)) & (1 << LCD_BUSY)) { -    } - -    /* the address counter is updated 4us after the busy flag is cleared */ -    delay(LCD_DELAY_BUSY_FLAG); - -    /* now read the address counter */ -    return (lcd_read(0)); // return address counter - -} /* lcd_waitbusy */ - -/************************************************************************* -Move cursor to the start of next line or to the first line if the cursor -is already on the last line. -*************************************************************************/ -static inline void lcd_newline(uint8_t pos) { -    register uint8_t addressCounter; - -#if LCD_LINES == 1 -    addressCounter = 0; -#endif -#if LCD_LINES == 2 -    if (pos < (LCD_START_LINE2)) -        addressCounter = LCD_START_LINE2; -    else -        addressCounter = LCD_START_LINE1; -#endif -#if LCD_LINES == 4 -#    if KS0073_4LINES_MODE -    if (pos < LCD_START_LINE2) -        addressCounter = LCD_START_LINE2; -    else if ((pos >= LCD_START_LINE2) && (pos < LCD_START_LINE3)) -        addressCounter = LCD_START_LINE3; -    else if ((pos >= LCD_START_LINE3) && (pos < LCD_START_LINE4)) -        addressCounter = LCD_START_LINE4; -    else -        addressCounter = LCD_START_LINE1; -#    else -    if (pos < LCD_START_LINE3) -        addressCounter = LCD_START_LINE2; -    else if ((pos >= LCD_START_LINE2) && (pos < LCD_START_LINE4)) -        addressCounter = LCD_START_LINE3; -    else if ((pos >= LCD_START_LINE3) && (pos < LCD_START_LINE2)) -        addressCounter = LCD_START_LINE4; -    else -        addressCounter = LCD_START_LINE1; -#    endif -#endif -    lcd_command((1 << LCD_DDRAM) + addressCounter); - -} /* lcd_newline */ - -/* -** PUBLIC FUNCTIONS -*/ - -/************************************************************************* -Send LCD controller instruction command -Input:   instruction to send to LCD controller, see HD44780 data sheet -Returns: none -*************************************************************************/ -void lcd_command(uint8_t cmd) { -    lcd_waitbusy(); -    lcd_write(cmd, 0); -} - -/************************************************************************* -Send data byte to LCD controller -Input:   data to send to LCD controller, see HD44780 data sheet -Returns: none -*************************************************************************/ -void lcd_data(uint8_t data) { -    lcd_waitbusy(); -    lcd_write(data, 1); -} - -/************************************************************************* -Set cursor to specified position -Input:    x  horizontal position  (0: left most position) -          y  vertical position    (0: first line) -Returns:  none -*************************************************************************/ -void lcd_gotoxy(uint8_t x, uint8_t y) { -#if LCD_LINES == 1 -    lcd_command((1 << LCD_DDRAM) + LCD_START_LINE1 + x); -#endif -#if LCD_LINES == 2 -    if (y == 0) -        lcd_command((1 << LCD_DDRAM) + LCD_START_LINE1 + x); -    else -        lcd_command((1 << LCD_DDRAM) + LCD_START_LINE2 + x); -#endif -#if LCD_LINES == 4 -    if (y == 0) -        lcd_command((1 << LCD_DDRAM) + LCD_START_LINE1 + x); -    else if (y == 1) -        lcd_command((1 << LCD_DDRAM) + LCD_START_LINE2 + x); -    else if (y == 2) -        lcd_command((1 << LCD_DDRAM) + LCD_START_LINE3 + x); -    else /* y==3 */ -        lcd_command((1 << LCD_DDRAM) + LCD_START_LINE4 + x); -#endif - -} /* lcd_gotoxy */ - -/************************************************************************* -*************************************************************************/ -int lcd_getxy(void) { -    return lcd_waitbusy(); -} - -/************************************************************************* -Clear display and set cursor to home position -*************************************************************************/ -void lcd_clrscr(void) { -    lcd_command(1 << LCD_CLR); -} - -/************************************************************************* -Set cursor to home position -*************************************************************************/ -void lcd_home(void) { -    lcd_command(1 << LCD_HOME); -} - -/************************************************************************* -Display character at current cursor position -Input:    character to be displayed -Returns:  none -*************************************************************************/ -void lcd_putc(char c) { -    uint8_t pos; - -    pos = lcd_waitbusy(); // read busy-flag and address counter -    if (c == '\n') { -        lcd_newline(pos); -    } else { -#if LCD_WRAP_LINES == 1 -#    if LCD_LINES == 1 -        if (pos == LCD_START_LINE1 + LCD_DISP_LENGTH) { -            lcd_write((1 << LCD_DDRAM) + LCD_START_LINE1, 0); -        } -#    elif LCD_LINES == 2 -        if (pos == LCD_START_LINE1 + LCD_DISP_LENGTH) { -            lcd_write((1 << LCD_DDRAM) + LCD_START_LINE2, 0); -        } else if (pos == LCD_START_LINE2 + LCD_DISP_LENGTH) { -            lcd_write((1 << LCD_DDRAM) + LCD_START_LINE1, 0); -        } -#    elif LCD_LINES == 4 -        if (pos == LCD_START_LINE1 + LCD_DISP_LENGTH) { -            lcd_write((1 << LCD_DDRAM) + LCD_START_LINE2, 0); -        } else if (pos == LCD_START_LINE2 + LCD_DISP_LENGTH) { -            lcd_write((1 << LCD_DDRAM) + LCD_START_LINE3, 0); -        } else if (pos == LCD_START_LINE3 + LCD_DISP_LENGTH) { -            lcd_write((1 << LCD_DDRAM) + LCD_START_LINE4, 0); -        } else if (pos == LCD_START_LINE4 + LCD_DISP_LENGTH) { -            lcd_write((1 << LCD_DDRAM) + LCD_START_LINE1, 0); -        } -#    endif -        lcd_waitbusy(); -#endif -        lcd_write(c, 1); -    } - -} /* lcd_putc */ - -/************************************************************************* -Display string without auto linefeed -Input:    string to be displayed -Returns:  none -*************************************************************************/ -void lcd_puts(const char *s) -/* print string on lcd (no auto linefeed) */ -{ -    register char c; - -    while ((c = *s++)) { -        lcd_putc(c); -    } - -} /* lcd_puts */ - -/************************************************************************* -Display string from program memory without auto linefeed -Input:     string from program memory be be displayed -Returns:   none -*************************************************************************/ -void lcd_puts_p(const char *progmem_s) -/* print string from program memory on lcd (no auto linefeed) */ -{ -    register char c; - -    while ((c = pgm_read_byte(progmem_s++))) { -        lcd_putc(c); -    } - -} /* lcd_puts_p */ - -/************************************************************************* -Initialize display and select type of cursor -Input:    dispAttr LCD_DISP_OFF            display off -                   LCD_DISP_ON             display on, cursor off -                   LCD_DISP_ON_CURSOR      display on, cursor on -                   LCD_DISP_CURSOR_BLINK   display on, cursor on flashing -Returns:  none -*************************************************************************/ -void lcd_init(uint8_t dispAttr) { -#if LCD_IO_MODE -    /* -     *  Initialize LCD to 4 bit I/O mode -     */ - -    if ((&LCD_DATA0_PORT == &LCD_DATA1_PORT) && (&LCD_DATA1_PORT == &LCD_DATA2_PORT) && (&LCD_DATA2_PORT == &LCD_DATA3_PORT) && (&LCD_RS_PORT == &LCD_DATA0_PORT) && (&LCD_RW_PORT == &LCD_DATA0_PORT) && (&LCD_E_PORT == &LCD_DATA0_PORT) && (LCD_DATA0_PIN == 0) && (LCD_DATA1_PIN == 1) && (LCD_DATA2_PIN == 2) && (LCD_DATA3_PIN == 3) && (LCD_RS_PIN == 4) && (LCD_RW_PIN == 5) && (LCD_E_PIN == 6)) { -        /* configure all port bits as output (all LCD lines on same port) */ -        DDR(LCD_DATA0_PORT) |= 0x7F; -    } else if ((&LCD_DATA0_PORT == &LCD_DATA1_PORT) && (&LCD_DATA1_PORT == &LCD_DATA2_PORT) && (&LCD_DATA2_PORT == &LCD_DATA3_PORT) && (LCD_DATA0_PIN == 0) && (LCD_DATA1_PIN == 1) && (LCD_DATA2_PIN == 2) && (LCD_DATA3_PIN == 3)) { -        /* configure all port bits as output (all LCD data lines on same port, but control lines on different ports) */ -        DDR(LCD_DATA0_PORT) |= 0x0F; -        DDR(LCD_RS_PORT) |= _BV(LCD_RS_PIN); -        DDR(LCD_RW_PORT) |= _BV(LCD_RW_PIN); -        DDR(LCD_E_PORT) |= _BV(LCD_E_PIN); -    } else { -        /* configure all port bits as output (LCD data and control lines on different ports */ -        DDR(LCD_RS_PORT) |= _BV(LCD_RS_PIN); -        DDR(LCD_RW_PORT) |= _BV(LCD_RW_PIN); -        DDR(LCD_E_PORT) |= _BV(LCD_E_PIN); -        DDR(LCD_DATA0_PORT) |= _BV(LCD_DATA0_PIN); -        DDR(LCD_DATA1_PORT) |= _BV(LCD_DATA1_PIN); -        DDR(LCD_DATA2_PORT) |= _BV(LCD_DATA2_PIN); -        DDR(LCD_DATA3_PORT) |= _BV(LCD_DATA3_PIN); -    } -    delay(LCD_DELAY_BOOTUP); /* wait 16ms or more after power-on       */ - -    /* initial write to lcd is 8bit */ -    LCD_DATA1_PORT |= _BV(LCD_DATA1_PIN); // LCD_FUNCTION>>4; -    LCD_DATA0_PORT |= _BV(LCD_DATA0_PIN); // LCD_FUNCTION_8BIT>>4; -    lcd_e_toggle(); -    delay(LCD_DELAY_INIT); /* delay, busy flag can't be checked here */ - -    /* repeat last command */ -    lcd_e_toggle(); -    delay(LCD_DELAY_INIT_REP); /* delay, busy flag can't be checked here */ - -    /* repeat last command a third time */ -    lcd_e_toggle(); -    delay(LCD_DELAY_INIT_REP); /* delay, busy flag can't be checked here */ - -    /* now configure for 4bit mode */ -    LCD_DATA0_PORT &= ~_BV(LCD_DATA0_PIN); // LCD_FUNCTION_4BIT_1LINE>>4 -    lcd_e_toggle(); -    delay(LCD_DELAY_INIT_4BIT); /* some displays need this additional delay */ - -    /* from now the LCD only accepts 4 bit I/O, we can use lcd_command() */ -#else -    /* -     * Initialize LCD to 8 bit memory mapped mode -     */ - -    /* enable external SRAM (memory mapped lcd) and one wait state */ -    MCUCR = _BV(SRE) | _BV(SRW); - -    /* reset LCD */ -    delay(LCD_DELAY_BOOTUP);               /* wait 16ms after power-on     */ -    lcd_write(LCD_FUNCTION_8BIT_1LINE, 0); /* function set: 8bit interface */ -    delay(LCD_DELAY_INIT);                 /* wait 5ms                     */ -    lcd_write(LCD_FUNCTION_8BIT_1LINE, 0); /* function set: 8bit interface */ -    delay(LCD_DELAY_INIT_REP);             /* wait 64us                    */ -    lcd_write(LCD_FUNCTION_8BIT_1LINE, 0); /* function set: 8bit interface */ -    delay(LCD_DELAY_INIT_REP);             /* wait 64us                    */ -#endif - -#if KS0073_4LINES_MODE -    /* Display with KS0073 controller requires special commands for enabling 4 line mode */ -    lcd_command(KS0073_EXTENDED_FUNCTION_REGISTER_ON); -    lcd_command(KS0073_4LINES_MODE); -    lcd_command(KS0073_EXTENDED_FUNCTION_REGISTER_OFF); -#else -    lcd_command(LCD_FUNCTION_DEFAULT);     /* function set: display lines  */ -#endif -    lcd_command(LCD_DISP_OFF);     /* display off                  */ -    lcd_clrscr();                  /* display clear                */ -    lcd_command(LCD_MODE_DEFAULT); /* set entry mode               */ -    lcd_command(dispAttr);         /* display/cursor control       */ - -} /* lcd_init */ diff --git a/platforms/avr/drivers/hd44780.h b/platforms/avr/drivers/hd44780.h deleted file mode 100644 index 08e60f8a44..0000000000 --- a/platforms/avr/drivers/hd44780.h +++ /dev/null @@ -1,348 +0,0 @@ -/************************************************************************* - Title	:   C include file for the HD44780U LCD library (lcd.c) - Author:    Peter Fleury <pfleury@gmx.ch>  http://tinyurl.com/peterfleury - License:   GNU General Public License Version 3 - File:	    $Id: lcd.h,v 1.14.2.4 2015/01/20 17:16:07 peter Exp $ - Software:  AVR-GCC 4.x - Hardware:  any AVR device, memory mapped mode only for AVR with -            memory mapped interface (AT90S8515/ATmega8515/ATmega128) -***************************************************************************/ - -/** - @mainpage - Collection of libraries for AVR-GCC - @author Peter Fleury pfleury@gmx.ch http://tinyurl.com/peterfleury - @copyright (C) 2015 Peter Fleury, GNU General Public License Version 3 - - @file - @defgroup pfleury_lcd LCD library <lcd.h> - @code #include <lcd.h> @endcode - - @brief Basic routines for interfacing a HD44780U-based character LCD display - - LCD character displays can be found in many devices, like espresso machines, laser printers. - The Hitachi HD44780 controller and its compatible controllers like Samsung KS0066U have become an industry standard for these types of displays. - - This library allows easy interfacing with a HD44780 compatible display and can be - operated in memory mapped mode (LCD_IO_MODE defined as 0 in the include file lcd.h.) or in - 4-bit IO port mode (LCD_IO_MODE defined as 1). 8-bit IO port mode is not supported. - - Memory mapped mode is compatible with old Kanda STK200 starter kit, but also supports - generation of R/W signal through A8 address line. - - @see The chapter <a href=" http://homepage.hispeed.ch/peterfleury/avr-lcd44780.html" target="_blank">Interfacing a HD44780 Based LCD to an AVR</a> -      on my home page, which shows example circuits how to connect an LCD to an AVR controller. - - @author Peter Fleury pfleury@gmx.ch http://tinyurl.com/peterfleury - - @version   2.0 - - @copyright (C) 2015 Peter Fleury, GNU General Public License Version 3 - -*/ - -#pragma once - -#include <inttypes.h> -#include <avr/pgmspace.h> - -#if (__GNUC__ * 100 + __GNUC_MINOR__) < 405 -#    error "This library requires AVR-GCC 4.5 or later, update to newer AVR-GCC compiler !" -#endif - -/**@{*/ - -/* - * LCD and target specific definitions below can be defined in a separate include file with name lcd_definitions.h instead modifying this file - * by adding -D_LCD_DEFINITIONS_FILE to the CDEFS section in the Makefile - * All definitions added to the file lcd_definitions.h will override the default definitions from lcd.h - */ -#ifdef _LCD_DEFINITIONS_FILE -#    include "lcd_definitions.h" -#endif - -/** - * @name  Definition for LCD controller type - * Use 0 for HD44780 controller, change to 1 for displays with KS0073 controller. - */ -#ifndef LCD_CONTROLLER_KS0073 -#    define LCD_CONTROLLER_KS0073 0 /**< Use 0 for HD44780 controller, 1 for KS0073 controller */ -#endif - -/** - * @name  Definitions for Display Size - * Change these definitions to adapt setting to your display - * - * These definitions can be defined in a separate include file \b lcd_definitions.h instead modifying this file by - * adding -D_LCD_DEFINITIONS_FILE to the CDEFS section in the Makefile. - * All definitions added to the file lcd_definitions.h will override the default definitions from lcd.h - * - */ -#ifndef LCD_LINES -#    define LCD_LINES 2 /**< number of visible lines of the display */ -#endif -#ifndef LCD_DISP_LENGTH -#    define LCD_DISP_LENGTH 16 /**< visibles characters per line of the display */ -#endif -#ifndef LCD_LINE_LENGTH -#    define LCD_LINE_LENGTH 0x40 /**< internal line length of the display    */ -#endif -#ifndef LCD_START_LINE1 -#    define LCD_START_LINE1 0x00 /**< DDRAM address of first char of line 1 */ -#endif -#ifndef LCD_START_LINE2 -#    define LCD_START_LINE2 0x40 /**< DDRAM address of first char of line 2 */ -#endif -#ifndef LCD_START_LINE3 -#    define LCD_START_LINE3 0x14 /**< DDRAM address of first char of line 3 */ -#endif -#ifndef LCD_START_LINE4 -#    define LCD_START_LINE4 0x54 /**< DDRAM address of first char of line 4 */ -#endif -#ifndef LCD_WRAP_LINES -#    define LCD_WRAP_LINES 0 /**< 0: no wrap, 1: wrap at end of visibile line */ -#endif - -/** - * @name Definitions for 4-bit IO mode - * - * The four LCD data lines and the three control lines RS, RW, E can be on the - * same port or on different ports. - * Change LCD_RS_PORT, LCD_RW_PORT, LCD_E_PORT if you want the control lines on - * different ports. - * - * Normally the four data lines should be mapped to bit 0..3 on one port, but it - * is possible to connect these data lines in different order or even on different - * ports by adapting the LCD_DATAx_PORT and LCD_DATAx_PIN definitions. - * - * Adjust these definitions to your target.\n - * These definitions can be defined in a separate include file \b lcd_definitions.h instead modifying this file by - * adding \b -D_LCD_DEFINITIONS_FILE to the \b CDEFS section in the Makefile. - * All definitions added to the file lcd_definitions.h will override the default definitions from lcd.h - * - */ -#define LCD_IO_MODE 1 /**< 0: memory mapped mode, 1: IO port mode */ - -#if LCD_IO_MODE - -#    ifndef LCD_PORT -#        define LCD_PORT PORTA /**< port for the LCD lines   */ -#    endif -#    ifndef LCD_DATA0_PORT -#        define LCD_DATA0_PORT LCD_PORT /**< port for 4bit data bit 0 */ -#    endif -#    ifndef LCD_DATA1_PORT -#        define LCD_DATA1_PORT LCD_PORT /**< port for 4bit data bit 1 */ -#    endif -#    ifndef LCD_DATA2_PORT -#        define LCD_DATA2_PORT LCD_PORT /**< port for 4bit data bit 2 */ -#    endif -#    ifndef LCD_DATA3_PORT -#        define LCD_DATA3_PORT LCD_PORT /**< port for 4bit data bit 3 */ -#    endif -#    ifndef LCD_DATA0_PIN -#        define LCD_DATA0_PIN 4 /**< pin for 4bit data bit 0  */ -#    endif -#    ifndef LCD_DATA1_PIN -#        define LCD_DATA1_PIN 5 /**< pin for 4bit data bit 1  */ -#    endif -#    ifndef LCD_DATA2_PIN -#        define LCD_DATA2_PIN 6 /**< pin for 4bit data bit 2  */ -#    endif -#    ifndef LCD_DATA3_PIN -#        define LCD_DATA3_PIN 7 /**< pin for 4bit data bit 3  */ -#    endif -#    ifndef LCD_RS_PORT -#        define LCD_RS_PORT LCD_PORT /**< port for RS line         */ -#    endif -#    ifndef LCD_RS_PIN -#        define LCD_RS_PIN 3 /**< pin  for RS line         */ -#    endif -#    ifndef LCD_RW_PORT -#        define LCD_RW_PORT LCD_PORT /**< port for RW line         */ -#    endif -#    ifndef LCD_RW_PIN -#        define LCD_RW_PIN 2 /**< pin  for RW line         */ -#    endif -#    ifndef LCD_E_PORT -#        define LCD_E_PORT LCD_PORT /**< port for Enable line     */ -#    endif -#    ifndef LCD_E_PIN -#        define LCD_E_PIN 1 /**< pin  for Enable line     */ -#    endif - -#elif defined(__AVR_AT90S4414__) || defined(__AVR_AT90S8515__) || defined(__AVR_ATmega64__) || defined(__AVR_ATmega8515__) || defined(__AVR_ATmega103__) || defined(__AVR_ATmega128__) || defined(__AVR_ATmega161__) || defined(__AVR_ATmega162__) -/* - * memory mapped mode is only supported when the device has an external data memory interface - */ -#    define LCD_IO_DATA 0xC000     /* A15=E=1, A14=RS=1                 */ -#    define LCD_IO_FUNCTION 0x8000 /* A15=E=1, A14=RS=0                 */ -#    define LCD_IO_READ 0x0100     /* A8 =R/W=1 (R/W: 1=Read, 0=Write   */ - -#else -#    error "external data memory interface not available for this device, use 4-bit IO port mode" - -#endif - -/** - * @name Definitions of delays - * Used to calculate delay timers. - * Adapt the F_CPU define in the Makefile to the clock frequency in Hz of your target - * - * These delay times can be adjusted, if some displays require different delays.\n - * These definitions can be defined in a separate include file \b lcd_definitions.h instead modifying this file by - * adding \b -D_LCD_DEFINITIONS_FILE to the \b CDEFS section in the Makefile. - * All definitions added to the file lcd_definitions.h will override the default definitions from lcd.h - */ -#ifndef LCD_DELAY_BOOTUP -#    define LCD_DELAY_BOOTUP 16000 /**< delay in micro seconds after power-on  */ -#endif -#ifndef LCD_DELAY_INIT -#    define LCD_DELAY_INIT 5000 /**< delay in micro seconds after initialization command sent  */ -#endif -#ifndef LCD_DELAY_INIT_REP -#    define LCD_DELAY_INIT_REP 64 /**< delay in micro seconds after initialization command repeated */ -#endif -#ifndef LCD_DELAY_INIT_4BIT -#    define LCD_DELAY_INIT_4BIT 64 /**< delay in micro seconds after setting 4-bit mode */ -#endif -#ifndef LCD_DELAY_BUSY_FLAG -#    define LCD_DELAY_BUSY_FLAG 4 /**< time in micro seconds the address counter is updated after busy flag is cleared */ -#endif -#ifndef LCD_DELAY_ENABLE_PULSE -#    define LCD_DELAY_ENABLE_PULSE 1 /**< enable signal pulse width in micro seconds */ -#endif - -/** - * @name Definitions for LCD command instructions - * The constants define the various LCD controller instructions which can be passed to the - * function lcd_command(), see HD44780 data sheet for a complete description. - */ - -/* instruction register bit positions, see HD44780U data sheet */ -#define LCD_CLR 0             /* DB0: clear display                  */ -#define LCD_HOME 1            /* DB1: return to home position        */ -#define LCD_ENTRY_MODE 2      /* DB2: set entry mode                 */ -#define LCD_ENTRY_INC 1       /*   DB1: 1=increment, 0=decrement     */ -#define LCD_ENTRY_SHIFT 0     /*   DB2: 1=display shift on           */ -#define LCD_ON 3              /* DB3: turn lcd/cursor on             */ -#define LCD_ON_DISPLAY 2      /*   DB2: turn display on              */ -#define LCD_ON_CURSOR 1       /*   DB1: turn cursor on               */ -#define LCD_ON_BLINK 0        /*     DB0: blinking cursor ?          */ -#define LCD_MOVE 4            /* DB4: move cursor/display            */ -#define LCD_MOVE_DISP 3       /*   DB3: move display (0-> cursor) ?  */ -#define LCD_MOVE_RIGHT 2      /*   DB2: move right (0-> left) ?      */ -#define LCD_FUNCTION 5        /* DB5: function set                   */ -#define LCD_FUNCTION_8BIT 4   /*   DB4: set 8BIT mode (0->4BIT mode) */ -#define LCD_FUNCTION_2LINES 3 /*   DB3: two lines (0->one line)      */ -#define LCD_FUNCTION_10DOTS 2 /*   DB2: 5x10 font (0->5x7 font)      */ -#define LCD_CGRAM 6           /* DB6: set CG RAM address             */ -#define LCD_DDRAM 7           /* DB7: set DD RAM address             */ -#define LCD_BUSY 7            /* DB7: LCD is busy                    */ - -/* set entry mode: display shift on/off, dec/inc cursor move direction */ -#define LCD_ENTRY_DEC 0x04       /* display shift off, dec cursor move dir */ -#define LCD_ENTRY_DEC_SHIFT 0x05 /* display shift on,  dec cursor move dir */ -#define LCD_ENTRY_INC_ 0x06      /* display shift off, inc cursor move dir */ -#define LCD_ENTRY_INC_SHIFT 0x07 /* display shift on,  inc cursor move dir */ - -/* display on/off, cursor on/off, blinking char at cursor position */ -#define LCD_DISP_OFF 0x08             /* display off                            */ -#define LCD_DISP_ON 0x0C              /* display on, cursor off                 */ -#define LCD_DISP_ON_BLINK 0x0D        /* display on, cursor off, blink char     */ -#define LCD_DISP_ON_CURSOR 0x0E       /* display on, cursor on                  */ -#define LCD_DISP_ON_CURSOR_BLINK 0x0F /* display on, cursor on, blink char      */ - -/* move cursor/shift display */ -#define LCD_MOVE_CURSOR_LEFT 0x10  /* move cursor left  (decrement)          */ -#define LCD_MOVE_CURSOR_RIGHT 0x14 /* move cursor right (increment)          */ -#define LCD_MOVE_DISP_LEFT 0x18    /* shift display left                     */ -#define LCD_MOVE_DISP_RIGHT 0x1C   /* shift display right                    */ - -/* function set: set interface data length and number of display lines */ -#define LCD_FUNCTION_4BIT_1LINE 0x20  /* 4-bit interface, single line, 5x7 dots */ -#define LCD_FUNCTION_4BIT_2LINES 0x28 /* 4-bit interface, dual line,   5x7 dots */ -#define LCD_FUNCTION_8BIT_1LINE 0x30  /* 8-bit interface, single line, 5x7 dots */ -#define LCD_FUNCTION_8BIT_2LINES 0x38 /* 8-bit interface, dual line,   5x7 dots */ - -#define LCD_MODE_DEFAULT ((1 << LCD_ENTRY_MODE) | (1 << LCD_ENTRY_INC)) - -/** - *  @name Functions - */ - -/** - @brief    Initialize display and select type of cursor - @param    dispAttr \b LCD_DISP_OFF display off\n -                    \b LCD_DISP_ON display on, cursor off\n -                    \b LCD_DISP_ON_CURSOR display on, cursor on\n -                    \b LCD_DISP_ON_CURSOR_BLINK display on, cursor on flashing - @return  none -*/ -extern void lcd_init(uint8_t dispAttr); - -/** - @brief    Clear display and set cursor to home position - @return   none -*/ -extern void lcd_clrscr(void); - -/** - @brief    Set cursor to home position - @return   none -*/ -extern void lcd_home(void); - -/** - @brief    Set cursor to specified position - - @param    x horizontal position\n (0: left most position) - @param    y vertical position\n   (0: first line) - @return   none -*/ -extern void lcd_gotoxy(uint8_t x, uint8_t y); - -/** - @brief    Display character at current cursor position - @param    c character to be displayed - @return   none -*/ -extern void lcd_putc(char c); - -/** - @brief    Display string without auto linefeed - @param    s string to be displayed - @return   none -*/ -extern void lcd_puts(const char *s); - -/** - @brief    Display string from program memory without auto linefeed - @param    progmem_s string from program memory be be displayed - @return   none - @see      lcd_puts_P -*/ -extern void lcd_puts_p(const char *progmem_s); - -/** - @brief    Send LCD controller instruction command - @param    cmd instruction to send to LCD controller, see HD44780 data sheet - @return   none -*/ -extern void lcd_command(uint8_t cmd); - -/** - @brief    Send data byte to LCD controller - - Similar to lcd_putc(), but without interpreting LF - @param    data byte to send to LCD controller, see HD44780 data sheet - @return   none -*/ -extern void lcd_data(uint8_t data); - -/** - @brief macros for automatically storing string constant in program memory -*/ -#define lcd_puts_P(__s) lcd_puts_p(PSTR(__s)) - -/**@}*/ diff --git a/platforms/avr/platform.mk b/platforms/avr/platform.mk index 4d9cafaeef..9f304d2e20 100644 --- a/platforms/avr/platform.mk +++ b/platforms/avr/platform.mk @@ -18,6 +18,13 @@ COMPILEFLAGS += -ffunction-sections  COMPILEFLAGS += -fdata-sections  COMPILEFLAGS += -fpack-struct  COMPILEFLAGS += -fshort-enums +COMPILEFLAGS += -mcall-prologues + +# Linker relaxation is only possible if +# link time optimizations are not enabled. +ifeq ($(strip $(LTO_ENABLE)), no) +	COMPILEFLAGS += -mrelax +endif  ASFLAGS += $(AVR_ASFLAGS) @@ -28,7 +35,7 @@ CFLAGS += -fno-strict-aliasing  CXXFLAGS += $(COMPILEFLAGS)  CXXFLAGS += -fno-exceptions -std=c++11 -LDFLAGS +=-Wl,--gc-sections +LDFLAGS += -Wl,--gc-sections  OPT_DEFS += -DF_CPU=$(F_CPU)UL diff --git a/platforms/chibios/pin_defs.h b/platforms/chibios/_pin_defs.h index c03f8de0c2..a84d931cc2 100644 --- a/platforms/chibios/pin_defs.h +++ b/platforms/chibios/_pin_defs.h @@ -15,6 +15,12 @@   */  #pragma once +#if defined(MCU_KINETIS) +// TODO: including this avoids "error: expected identifier before '(' token" errors +//       here just to please KINETIS builds... +#    include <hal.h> +#endif +  // Defines mapping for Proton C replacement  #ifdef CONVERT_TO_PROTON_C  // Left side (front) diff --git a/platforms/chibios/boards/GENERIC_STM32_F303XC/configs/mcuconf.h b/platforms/chibios/boards/GENERIC_STM32_F303XC/configs/mcuconf.h index c6f5a8ac52..e0af4a276b 100644 --- a/platforms/chibios/boards/GENERIC_STM32_F303XC/configs/mcuconf.h +++ b/platforms/chibios/boards/GENERIC_STM32_F303XC/configs/mcuconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -186,7 +186,6 @@  /*   * PWM driver system settings.   */ -#define STM32_PWM_USE_ADVANCED              FALSE  #define STM32_PWM_USE_TIM1                  FALSE  #define STM32_PWM_USE_TIM2                  FALSE  #define STM32_PWM_USE_TIM3                  FALSE diff --git a/platforms/chibios/boards/GENERIC_STM32_F405XG/configs/mcuconf.h b/platforms/chibios/boards/GENERIC_STM32_F405XG/configs/mcuconf.h index 908a580a91..394e750256 100644 --- a/platforms/chibios/boards/GENERIC_STM32_F405XG/configs/mcuconf.h +++ b/platforms/chibios/boards/GENERIC_STM32_F405XG/configs/mcuconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -86,6 +86,28 @@  #define STM32_IRQ_EXTI21_PRIORITY           15  #define STM32_IRQ_EXTI22_PRIORITY           15 +#define STM32_IRQ_TIM1_BRK_TIM9_PRIORITY    7 +#define STM32_IRQ_TIM1_UP_TIM10_PRIORITY    7 +#define STM32_IRQ_TIM1_TRGCO_TIM11_PRIORITY 7 +#define STM32_IRQ_TIM1_CC_PRIORITY          7 +#define STM32_IRQ_TIM2_PRIORITY             7 +#define STM32_IRQ_TIM3_PRIORITY             7 +#define STM32_IRQ_TIM4_PRIORITY             7 +#define STM32_IRQ_TIM5_PRIORITY             7 +#define STM32_IRQ_TIM6_PRIORITY             7 +#define STM32_IRQ_TIM7_PRIORITY             7 +#define STM32_IRQ_TIM8_BRK_TIM12_PRIORITY   7 +#define STM32_IRQ_TIM8_UP_TIM13_PRIORITY    7 +#define STM32_IRQ_TIM8_TRGCO_TIM14_PRIORITY 7 +#define STM32_IRQ_TIM8_CC_PRIORITY          7 + +#define STM32_IRQ_USART1_PRIORITY           12 +#define STM32_IRQ_USART2_PRIORITY           12 +#define STM32_IRQ_USART3_PRIORITY           12 +#define STM32_IRQ_UART4_PRIORITY            12 +#define STM32_IRQ_UART5_PRIORITY            12 +#define STM32_IRQ_USART6_PRIORITY           12 +  /*   * ADC driver system settings.   */ @@ -137,21 +159,11 @@  #define STM32_GPT_USE_TIM7                  FALSE  #define STM32_GPT_USE_TIM8                  FALSE  #define STM32_GPT_USE_TIM9                  FALSE +#define STM32_GPT_USE_TIM10                 FALSE  #define STM32_GPT_USE_TIM11                 FALSE  #define STM32_GPT_USE_TIM12                 FALSE +#define STM32_GPT_USE_TIM13                 FALSE  #define STM32_GPT_USE_TIM14                 FALSE -#define STM32_GPT_TIM1_IRQ_PRIORITY         7 -#define STM32_GPT_TIM2_IRQ_PRIORITY         7 -#define STM32_GPT_TIM3_IRQ_PRIORITY         7 -#define STM32_GPT_TIM4_IRQ_PRIORITY         7 -#define STM32_GPT_TIM5_IRQ_PRIORITY         7 -#define STM32_GPT_TIM6_IRQ_PRIORITY         7 -#define STM32_GPT_TIM7_IRQ_PRIORITY         7 -#define STM32_GPT_TIM8_IRQ_PRIORITY         7 -#define STM32_GPT_TIM9_IRQ_PRIORITY         7 -#define STM32_GPT_TIM11_IRQ_PRIORITY        7 -#define STM32_GPT_TIM12_IRQ_PRIORITY        7 -#define STM32_GPT_TIM14_IRQ_PRIORITY        7  /*   * I2C driver system settings. @@ -199,13 +211,11 @@  #define STM32_ICU_USE_TIM5                  FALSE  #define STM32_ICU_USE_TIM8                  FALSE  #define STM32_ICU_USE_TIM9                  FALSE -#define STM32_ICU_TIM1_IRQ_PRIORITY         7 -#define STM32_ICU_TIM2_IRQ_PRIORITY         7 -#define STM32_ICU_TIM3_IRQ_PRIORITY         7 -#define STM32_ICU_TIM4_IRQ_PRIORITY         7 -#define STM32_ICU_TIM5_IRQ_PRIORITY         7 -#define STM32_ICU_TIM8_IRQ_PRIORITY         7 -#define STM32_ICU_TIM9_IRQ_PRIORITY         7 +#define STM32_ICU_USE_TIM10                 FALSE +#define STM32_ICU_USE_TIM11                 FALSE +#define STM32_ICU_USE_TIM12                 FALSE +#define STM32_ICU_USE_TIM13                 FALSE +#define STM32_ICU_USE_TIM14                 FALSE  /*   * MAC driver system settings. @@ -221,7 +231,6 @@  /*   * PWM driver system settings.   */ -#define STM32_PWM_USE_ADVANCED              FALSE  #define STM32_PWM_USE_TIM1                  FALSE  #define STM32_PWM_USE_TIM2                  FALSE  #define STM32_PWM_USE_TIM3                  FALSE @@ -229,13 +238,11 @@  #define STM32_PWM_USE_TIM5                  FALSE  #define STM32_PWM_USE_TIM8                  FALSE  #define STM32_PWM_USE_TIM9                  FALSE -#define STM32_PWM_TIM1_IRQ_PRIORITY         7 -#define STM32_PWM_TIM2_IRQ_PRIORITY         7 -#define STM32_PWM_TIM3_IRQ_PRIORITY         7 -#define STM32_PWM_TIM4_IRQ_PRIORITY         7 -#define STM32_PWM_TIM5_IRQ_PRIORITY         7 -#define STM32_PWM_TIM8_IRQ_PRIORITY         7 -#define STM32_PWM_TIM9_IRQ_PRIORITY         7 +#define STM32_PWM_USE_TIM10                 FALSE +#define STM32_PWM_USE_TIM11                 FALSE +#define STM32_PWM_USE_TIM12                 FALSE +#define STM32_PWM_USE_TIM13                 FALSE +#define STM32_PWM_USE_TIM14                 FALSE  /*   * RTC driver system settings. @@ -265,12 +272,6 @@  #define STM32_SERIAL_USE_UART4              FALSE  #define STM32_SERIAL_USE_UART5              FALSE  #define STM32_SERIAL_USE_USART6             FALSE -#define STM32_SERIAL_USART1_PRIORITY        12 -#define STM32_SERIAL_USART2_PRIORITY        12 -#define STM32_SERIAL_USART3_PRIORITY        12 -#define STM32_SERIAL_UART4_PRIORITY         12 -#define STM32_SERIAL_UART5_PRIORITY         12 -#define STM32_SERIAL_USART6_PRIORITY        12  /*   * SPI driver system settings. @@ -319,12 +320,6 @@  #define STM32_UART_UART5_TX_DMA_STREAM      STM32_DMA_STREAM_ID(1, 7)  #define STM32_UART_USART6_RX_DMA_STREAM     STM32_DMA_STREAM_ID(2, 2)  #define STM32_UART_USART6_TX_DMA_STREAM     STM32_DMA_STREAM_ID(2, 7) -#define STM32_UART_USART1_IRQ_PRIORITY      12 -#define STM32_UART_USART2_IRQ_PRIORITY      12 -#define STM32_UART_USART3_IRQ_PRIORITY      12 -#define STM32_UART_UART4_IRQ_PRIORITY       12 -#define STM32_UART_UART5_IRQ_PRIORITY       12 -#define STM32_UART_USART6_IRQ_PRIORITY      12  #define STM32_UART_USART1_DMA_PRIORITY      0  #define STM32_UART_USART2_DMA_PRIORITY      0  #define STM32_UART_USART3_DMA_PRIORITY      0 diff --git a/platforms/chibios/boards/GENERIC_STM32_F407XE/configs/mcuconf.h b/platforms/chibios/boards/GENERIC_STM32_F407XE/configs/mcuconf.h index 928ee56c71..07399ad2f7 100644 --- a/platforms/chibios/boards/GENERIC_STM32_F407XE/configs/mcuconf.h +++ b/platforms/chibios/boards/GENERIC_STM32_F407XE/configs/mcuconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -86,6 +86,28 @@  #define STM32_IRQ_EXTI21_PRIORITY           15  #define STM32_IRQ_EXTI22_PRIORITY           15 +#define STM32_IRQ_TIM1_BRK_TIM9_PRIORITY    7 +#define STM32_IRQ_TIM1_UP_TIM10_PRIORITY    7 +#define STM32_IRQ_TIM1_TRGCO_TIM11_PRIORITY 7 +#define STM32_IRQ_TIM1_CC_PRIORITY          7 +#define STM32_IRQ_TIM2_PRIORITY             7 +#define STM32_IRQ_TIM3_PRIORITY             7 +#define STM32_IRQ_TIM4_PRIORITY             7 +#define STM32_IRQ_TIM5_PRIORITY             7 +#define STM32_IRQ_TIM6_PRIORITY             7 +#define STM32_IRQ_TIM7_PRIORITY             7 +#define STM32_IRQ_TIM8_BRK_TIM12_PRIORITY   7 +#define STM32_IRQ_TIM8_UP_TIM13_PRIORITY    7 +#define STM32_IRQ_TIM8_TRGCO_TIM14_PRIORITY 7 +#define STM32_IRQ_TIM8_CC_PRIORITY          7 + +#define STM32_IRQ_USART1_PRIORITY           12 +#define STM32_IRQ_USART2_PRIORITY           12 +#define STM32_IRQ_USART3_PRIORITY           12 +#define STM32_IRQ_UART4_PRIORITY            12 +#define STM32_IRQ_UART5_PRIORITY            12 +#define STM32_IRQ_USART6_PRIORITY           12 +  /*   * ADC driver system settings.   */ @@ -137,21 +159,11 @@  #define STM32_GPT_USE_TIM7                  FALSE  #define STM32_GPT_USE_TIM8                  FALSE  #define STM32_GPT_USE_TIM9                  FALSE +#define STM32_GPT_USE_TIM10                 FALSE  #define STM32_GPT_USE_TIM11                 FALSE  #define STM32_GPT_USE_TIM12                 FALSE +#define STM32_GPT_USE_TIM13                 FALSE  #define STM32_GPT_USE_TIM14                 FALSE -#define STM32_GPT_TIM1_IRQ_PRIORITY         7 -#define STM32_GPT_TIM2_IRQ_PRIORITY         7 -#define STM32_GPT_TIM3_IRQ_PRIORITY         7 -#define STM32_GPT_TIM4_IRQ_PRIORITY         7 -#define STM32_GPT_TIM5_IRQ_PRIORITY         7 -#define STM32_GPT_TIM6_IRQ_PRIORITY         7 -#define STM32_GPT_TIM7_IRQ_PRIORITY         7 -#define STM32_GPT_TIM8_IRQ_PRIORITY         7 -#define STM32_GPT_TIM9_IRQ_PRIORITY         7 -#define STM32_GPT_TIM11_IRQ_PRIORITY        7 -#define STM32_GPT_TIM12_IRQ_PRIORITY        7 -#define STM32_GPT_TIM14_IRQ_PRIORITY        7  /*   * I2C driver system settings. @@ -199,13 +211,11 @@  #define STM32_ICU_USE_TIM5                  FALSE  #define STM32_ICU_USE_TIM8                  FALSE  #define STM32_ICU_USE_TIM9                  FALSE -#define STM32_ICU_TIM1_IRQ_PRIORITY         7 -#define STM32_ICU_TIM2_IRQ_PRIORITY         7 -#define STM32_ICU_TIM3_IRQ_PRIORITY         7 -#define STM32_ICU_TIM4_IRQ_PRIORITY         7 -#define STM32_ICU_TIM5_IRQ_PRIORITY         7 -#define STM32_ICU_TIM8_IRQ_PRIORITY         7 -#define STM32_ICU_TIM9_IRQ_PRIORITY         7 +#define STM32_ICU_USE_TIM10                 FALSE +#define STM32_ICU_USE_TIM11                 FALSE +#define STM32_ICU_USE_TIM12                 FALSE +#define STM32_ICU_USE_TIM13                 FALSE +#define STM32_ICU_USE_TIM14                 FALSE  /*   * MAC driver system settings. @@ -221,7 +231,6 @@  /*   * PWM driver system settings.   */ -#define STM32_PWM_USE_ADVANCED              FALSE  #define STM32_PWM_USE_TIM1                  FALSE  #define STM32_PWM_USE_TIM2                  FALSE  #define STM32_PWM_USE_TIM3                  FALSE @@ -229,13 +238,11 @@  #define STM32_PWM_USE_TIM5                  FALSE  #define STM32_PWM_USE_TIM8                  FALSE  #define STM32_PWM_USE_TIM9                  FALSE -#define STM32_PWM_TIM1_IRQ_PRIORITY         7 -#define STM32_PWM_TIM2_IRQ_PRIORITY         7 -#define STM32_PWM_TIM3_IRQ_PRIORITY         7 -#define STM32_PWM_TIM4_IRQ_PRIORITY         7 -#define STM32_PWM_TIM5_IRQ_PRIORITY         7 -#define STM32_PWM_TIM8_IRQ_PRIORITY         7 -#define STM32_PWM_TIM9_IRQ_PRIORITY         7 +#define STM32_PWM_USE_TIM10                 FALSE +#define STM32_PWM_USE_TIM11                 FALSE +#define STM32_PWM_USE_TIM12                 FALSE +#define STM32_PWM_USE_TIM13                 FALSE +#define STM32_PWM_USE_TIM14                 FALSE  /*   * RTC driver system settings. @@ -265,12 +272,6 @@  #define STM32_SERIAL_USE_UART4              FALSE  #define STM32_SERIAL_USE_UART5              FALSE  #define STM32_SERIAL_USE_USART6             FALSE -#define STM32_SERIAL_USART1_PRIORITY        12 -#define STM32_SERIAL_USART2_PRIORITY        12 -#define STM32_SERIAL_USART3_PRIORITY        12 -#define STM32_SERIAL_UART4_PRIORITY         12 -#define STM32_SERIAL_UART5_PRIORITY         12 -#define STM32_SERIAL_USART6_PRIORITY        12  /*   * SPI driver system settings. @@ -319,12 +320,6 @@  #define STM32_UART_UART5_TX_DMA_STREAM      STM32_DMA_STREAM_ID(1, 7)  #define STM32_UART_USART6_RX_DMA_STREAM     STM32_DMA_STREAM_ID(2, 2)  #define STM32_UART_USART6_TX_DMA_STREAM     STM32_DMA_STREAM_ID(2, 7) -#define STM32_UART_USART1_IRQ_PRIORITY      12 -#define STM32_UART_USART2_IRQ_PRIORITY      12 -#define STM32_UART_USART3_IRQ_PRIORITY      12 -#define STM32_UART_UART4_IRQ_PRIORITY       12 -#define STM32_UART_UART5_IRQ_PRIORITY       12 -#define STM32_UART_USART6_IRQ_PRIORITY      12  #define STM32_UART_USART1_DMA_PRIORITY      0  #define STM32_UART_USART2_DMA_PRIORITY      0  #define STM32_UART_USART3_DMA_PRIORITY      0 diff --git a/platforms/chibios/boards/GENERIC_STM32_G431XB/configs/mcuconf.h b/platforms/chibios/boards/GENERIC_STM32_G431XB/configs/mcuconf.h index d115028300..fd00280115 100644 --- a/platforms/chibios/boards/GENERIC_STM32_G431XB/configs/mcuconf.h +++ b/platforms/chibios/boards/GENERIC_STM32_G431XB/configs/mcuconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -39,6 +39,7 @@   * HAL driver system settings.   */  #define STM32_NO_INIT                       FALSE +#define STM32_CLOCK_DYNAMIC                 FALSE  #define STM32_VOS                           STM32_VOS_RANGE1  #define STM32_PWR_BOOST                     TRUE  #define STM32_PWR_CR2                       (PWR_CR2_PLS_LEV0) @@ -227,7 +228,6 @@  /*   * PWM driver system settings.   */ -#define STM32_PWM_USE_ADVANCED              FALSE  #define STM32_PWM_USE_TIM1                  FALSE  #define STM32_PWM_USE_TIM2                  FALSE  #define STM32_PWM_USE_TIM3                  FALSE @@ -240,6 +240,13 @@  /*   * RTC driver system settings.   */ +#define STM32_RTC_PRESA_VALUE               32 +#define STM32_RTC_PRESS_VALUE               1024 +#define STM32_RTC_CR_INIT                   0 +#define STM32_TAMP_CR1_INIT                 0 +#define STM32_TAMP_CR2_INIT                 0 +#define STM32_TAMP_FLTCR_INIT               0 +#define STM32_TAMP_IER_INIT                 0  /*   * SDC driver system settings. @@ -255,6 +262,15 @@  #define STM32_SERIAL_USE_LPUART1            FALSE  /* + * SIO driver system settings. + */ +#define STM32_SIO_USE_USART1                FALSE +#define STM32_SIO_USE_USART2                FALSE +#define STM32_SIO_USE_USART3                FALSE +#define STM32_SIO_USE_UART4                 FALSE +#define STM32_SIO_USE_LPUART1               FALSE + +/*   * SPI driver system settings.   */  #define STM32_SPI_USE_SPI1                  FALSE diff --git a/platforms/chibios/boards/GENERIC_STM32_G474XE/configs/mcuconf.h b/platforms/chibios/boards/GENERIC_STM32_G474XE/configs/mcuconf.h index 5710e2cb45..d6385da624 100644 --- a/platforms/chibios/boards/GENERIC_STM32_G474XE/configs/mcuconf.h +++ b/platforms/chibios/boards/GENERIC_STM32_G474XE/configs/mcuconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -41,6 +41,7 @@   * HAL driver system settings.   */  #define STM32_NO_INIT                       FALSE +#define STM32_CLOCK_DYNAMIC                 FALSE  #define STM32_VOS                           STM32_VOS_RANGE1  #define STM32_PWR_BOOST                     TRUE  #define STM32_PWR_CR2                       (PWR_CR2_PLS_LEV0) @@ -274,7 +275,6 @@  /*   * PWM driver system settings.   */ -#define STM32_PWM_USE_ADVANCED              FALSE  #define STM32_PWM_USE_TIM1                  FALSE  #define STM32_PWM_USE_TIM2                  FALSE  #define STM32_PWM_USE_TIM3                  FALSE @@ -289,6 +289,13 @@  /*   * RTC driver system settings.   */ +#define STM32_RTC_PRESA_VALUE               32 +#define STM32_RTC_PRESS_VALUE               1024 +#define STM32_RTC_CR_INIT                   0 +#define STM32_TAMP_CR1_INIT                 0 +#define STM32_TAMP_CR2_INIT                 0 +#define STM32_TAMP_FLTCR_INIT               0 +#define STM32_TAMP_IER_INIT                 0  /*   * SDC driver system settings. @@ -305,6 +312,16 @@  #define STM32_SERIAL_USE_LPUART1            FALSE  /* + * SIO driver system settings. + */ +#define STM32_SIO_USE_USART1                FALSE +#define STM32_SIO_USE_USART2                FALSE +#define STM32_SIO_USE_USART3                FALSE +#define STM32_SIO_USE_UART4                 FALSE +#define STM32_SIO_USE_UART5                 FALSE +#define STM32_SIO_USE_LPUART1               FALSE + +/*   * SPI driver system settings.   */  #define STM32_SPI_USE_SPI1                  FALSE @@ -383,5 +400,6 @@   */  #define STM32_WSPI_USE_QUADSPI1             FALSE  #define STM32_WSPI_QUADSPI1_DMA_STREAM      STM32_DMA_STREAM_ID(2, 7) +#define STM32_WSPI_QUADSPI1_PRESCALER_VALUE 1  #endif /* MCUCONF_H */ diff --git a/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/board.h b/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/board.h index 2e37d95fe3..de5f85acdd 100644 --- a/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/board.h +++ b/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/board.h @@ -18,7 +18,4 @@  #include_next "board.h"  #undef STM32L432xx - -// Pretend that we're an L443xx as the ChibiOS definitions for L4x2/L4x3 mistakenly don't enable GPIOH, I2C2, or SPI2. -// Until ChibiOS upstream is fixed, this should be kept at L443, as nothing in QMK currently utilises the crypto peripheral on the L443. -#define STM32L443xx +#define STM32L422xx diff --git a/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/config.h b/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/config.h index fc9055ccfb..d67de4cfe2 100644 --- a/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/config.h +++ b/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/config.h @@ -18,8 +18,6 @@  /* It is chip dependent, the correct number can be looked up by checking against ST's application note AN2606.   */ -#define PAL_STM32_OSPEED_HIGHEST PAL_STM32_OSPEED_HIGH -  #ifndef EARLY_INIT_PERFORM_BOOTLOADER_JUMP  #    define EARLY_INIT_PERFORM_BOOTLOADER_JUMP TRUE  #endif diff --git a/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/mcuconf.h b/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/mcuconf.h index 8ad5a8da21..47f1598b74 100644 --- a/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/mcuconf.h +++ b/platforms/chibios/boards/GENERIC_STM32_L412XB/configs/mcuconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -32,12 +32,7 @@  #define MCUCONF_H  #define STM32L4xx_MCUCONF -#define STM32L412_MCUCONF  #define STM32L422_MCUCONF -#define STM32L432_MCUCONF -#define STM32L433_MCUCONF -#define STM32L442_MCUCONF -#define STM32L443_MCUCONF  /*   * HAL driver system settings. @@ -52,16 +47,13 @@  #define STM32_HSE_ENABLED                   FALSE  #define STM32_LSE_ENABLED                   FALSE  #define STM32_MSIPLL_ENABLED                FALSE -#define STM32_ADC_CLOCK_ENABLED             TRUE -#define STM32_USB_CLOCK_ENABLED             TRUE -#define STM32_SAI1_CLOCK_ENABLED            TRUE -#define STM32_SAI2_CLOCK_ENABLED            TRUE  #define STM32_MSIRANGE                      STM32_MSIRANGE_4M  #define STM32_MSISRANGE                     STM32_MSISRANGE_4M  #define STM32_SW                            STM32_SW_PLL  #define STM32_PLLSRC                        STM32_PLLSRC_HSI16  #define STM32_PLLM_VALUE                    4  #define STM32_PLLN_VALUE                    80 +#define STM32_PLLPDIV_VALUE                 0  #define STM32_PLLP_VALUE                    7  #define STM32_PLLQ_VALUE                    4  #define STM32_PLLR_VALUE                    4 @@ -73,29 +65,22 @@  #define STM32_MCOPRE                        STM32_MCOPRE_DIV1  #define STM32_LSCOSEL                       STM32_LSCOSEL_NOCLOCK  #define STM32_PLLSAI1N_VALUE                72 +#define STM32_PLLSAI1PDIV_VALUE             6  #define STM32_PLLSAI1P_VALUE                7  #define STM32_PLLSAI1Q_VALUE                6  #define STM32_PLLSAI1R_VALUE                6 -#define STM32_PLLSAI2N_VALUE                72 -#define STM32_PLLSAI2P_VALUE                7 -#define STM32_PLLSAI2R_VALUE                6  /*   * Peripherals clock sources.   */  #define STM32_USART1SEL                     STM32_USART1SEL_SYSCLK  #define STM32_USART2SEL                     STM32_USART2SEL_SYSCLK -#define STM32_USART3SEL                     STM32_USART3SEL_SYSCLK -#define STM32_UART4SEL                      STM32_UART4SEL_SYSCLK -#define STM32_UART5SEL                      STM32_UART5SEL_SYSCLK  #define STM32_LPUART1SEL                    STM32_LPUART1SEL_SYSCLK  #define STM32_I2C1SEL                       STM32_I2C1SEL_SYSCLK -#define STM32_I2C2SEL                       STM32_I2C2SEL_SYSCLK  #define STM32_I2C3SEL                       STM32_I2C3SEL_SYSCLK  #define STM32_LPTIM1SEL                     STM32_LPTIM1SEL_PCLK1  #define STM32_LPTIM2SEL                     STM32_LPTIM2SEL_PCLK1  #define STM32_SAI1SEL                       STM32_SAI1SEL_OFF -#define STM32_SAI2SEL                       STM32_SAI2SEL_OFF  #define STM32_CLK48SEL                      STM32_CLK48SEL_HSI48  #define STM32_ADCSEL                        STM32_ADCSEL_SYSCLK  #define STM32_SWPMI1SEL                     STM32_SWPMI1SEL_PCLK1 @@ -127,7 +112,6 @@  #define STM32_IRQ_USART1_PRIORITY           12  #define STM32_IRQ_USART2_PRIORITY           12 -#define STM32_IRQ_USART3_PRIORITY           12  #define STM32_IRQ_LPUART1_PRIORITY          12  /* @@ -137,29 +121,15 @@  #define STM32_ADC_USE_ADC1                  FALSE  #define STM32_ADC_ADC1_DMA_STREAM           STM32_DMA_STREAM_ID(1, 1)  #define STM32_ADC_ADC1_DMA_PRIORITY         2 +#define STM32_ADC_USE_ADC2                  FALSE +#define STM32_ADC_ADC2_DMA_STREAM           STM32_DMA_STREAM_ID(1, 2) +#define STM32_ADC_ADC2_DMA_PRIORITY         2  #define STM32_ADC_ADC12_IRQ_PRIORITY        5  #define STM32_ADC_ADC1_DMA_IRQ_PRIORITY     5 +#define STM32_ADC_ADC2_DMA_IRQ_PRIORITY     5  #define STM32_ADC_ADC123_CLOCK_MODE         ADC_CCR_CKMODE_AHB_DIV1  #define STM32_ADC_ADC123_PRESC              ADC_CCR_PRESC_DIV2 -/* - * CAN driver system settings. - */ -#define STM32_CAN_USE_CAN1                  FALSE -#define STM32_CAN_CAN1_IRQ_PRIORITY         11 - -/* - * DAC driver system settings. - */ -#define STM32_DAC_DUAL_MODE                 FALSE -#define STM32_DAC_USE_DAC1_CH1              FALSE -#define STM32_DAC_USE_DAC1_CH2              FALSE -#define STM32_DAC_DAC1_CH1_IRQ_PRIORITY     10 -#define STM32_DAC_DAC1_CH2_IRQ_PRIORITY     10 -#define STM32_DAC_DAC1_CH1_DMA_PRIORITY     2 -#define STM32_DAC_DAC1_CH2_DMA_PRIORITY     2 -#define STM32_DAC_DAC1_CH1_DMA_STREAM       STM32_DMA_STREAM_ID(2, 4) -#define STM32_DAC_DAC1_CH2_DMA_STREAM       STM32_DMA_STREAM_ID(1, 4)  /*   * GPT driver system settings. @@ -198,7 +168,6 @@  /*   * PWM driver system settings.   */ -#define STM32_PWM_USE_ADVANCED              FALSE  #define STM32_PWM_USE_TIM1                  FALSE  #define STM32_PWM_USE_TIM2                  FALSE  #define STM32_PWM_USE_TIM15                 FALSE @@ -218,23 +187,22 @@  #define STM32_SERIAL_USE_USART1             FALSE  #define STM32_SERIAL_USE_USART2             FALSE  #define STM32_SERIAL_USE_LPUART1            FALSE -#define STM32_SERIAL_USART1_PRIORITY        12 -#define STM32_SERIAL_USART2_PRIORITY        12 -#define STM32_SERIAL_LPUART1_PRIORITY       12 + +/* + * SIO driver system settings. + */ +#define STM32_SIO_USE_USART1                FALSE +#define STM32_SIO_USE_USART2                FALSE +#define STM32_SIO_USE_LPUART1               FALSE  /*   * SPI driver system settings.   */  #define STM32_SPI_USE_SPI1                  FALSE -#define STM32_SPI_USE_SPI3                  FALSE  #define STM32_SPI_SPI1_RX_DMA_STREAM        STM32_DMA_STREAM_ID(2, 3)  #define STM32_SPI_SPI1_TX_DMA_STREAM        STM32_DMA_STREAM_ID(2, 4) -#define STM32_SPI_SPI3_RX_DMA_STREAM        STM32_DMA_STREAM_ID(2, 1) -#define STM32_SPI_SPI3_TX_DMA_STREAM        STM32_DMA_STREAM_ID(2, 2)  #define STM32_SPI_SPI1_DMA_PRIORITY         1 -#define STM32_SPI_SPI3_DMA_PRIORITY         1  #define STM32_SPI_SPI1_IRQ_PRIORITY         10 -#define STM32_SPI_SPI3_IRQ_PRIORITY         10  #define STM32_SPI_DMA_ERROR_HOOK(spip)      osalSysHalt("DMA failure")  /* diff --git a/platforms/chibios/boards/GENERIC_STM32_L432XC/configs/config.h b/platforms/chibios/boards/GENERIC_STM32_L432XC/configs/config.h index b1838b30a8..839d031ca4 100644 --- a/platforms/chibios/boards/GENERIC_STM32_L432XC/configs/config.h +++ b/platforms/chibios/boards/GENERIC_STM32_L432XC/configs/config.h @@ -2,9 +2,6 @@  // SPDX-License-Identifier: GPL-2.0-or-later  #pragma once -// Fixup equivalent usages within QMK as the base board definitions only go up to high -#define PAL_STM32_OSPEED_HIGHEST PAL_STM32_OSPEED_HIGH -  #ifndef EARLY_INIT_PERFORM_BOOTLOADER_JUMP  #    define EARLY_INIT_PERFORM_BOOTLOADER_JUMP TRUE  #endif diff --git a/platforms/chibios/boards/GENERIC_STM32_L432XC/configs/mcuconf.h b/platforms/chibios/boards/GENERIC_STM32_L432XC/configs/mcuconf.h index 707134d49e..be64b04812 100644 --- a/platforms/chibios/boards/GENERIC_STM32_L432XC/configs/mcuconf.h +++ b/platforms/chibios/boards/GENERIC_STM32_L432XC/configs/mcuconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -33,7 +33,6 @@  #define STM32L4xx_MCUCONF  #define STM32L432_MCUCONF -#define STM32L433_MCUCONF  /*   * HAL driver system settings. @@ -183,7 +182,6 @@  /*   * PWM driver system settings.   */ -#define STM32_PWM_USE_ADVANCED              FALSE  #define STM32_PWM_USE_TIM1                  FALSE  #define STM32_PWM_USE_TIM2                  FALSE  #define STM32_PWM_USE_TIM15                 FALSE @@ -203,9 +201,13 @@  #define STM32_SERIAL_USE_USART1             FALSE  #define STM32_SERIAL_USE_USART2             FALSE  #define STM32_SERIAL_USE_LPUART1            FALSE -#define STM32_SERIAL_USART1_PRIORITY        12 -#define STM32_SERIAL_USART2_PRIORITY        12 -#define STM32_SERIAL_LPUART1_PRIORITY       12 + +/* + * SIO driver system settings. + */ +#define STM32_SIO_USE_USART1                FALSE +#define STM32_SIO_USE_USART2                FALSE +#define STM32_SIO_USE_LPUART1               FALSE  /*   * SPI driver system settings. diff --git a/platforms/chibios/boards/GENERIC_STM32_L433XC/configs/config.h b/platforms/chibios/boards/GENERIC_STM32_L433XC/configs/config.h index fc9055ccfb..d67de4cfe2 100644 --- a/platforms/chibios/boards/GENERIC_STM32_L433XC/configs/config.h +++ b/platforms/chibios/boards/GENERIC_STM32_L433XC/configs/config.h @@ -18,8 +18,6 @@  /* It is chip dependent, the correct number can be looked up by checking against ST's application note AN2606.   */ -#define PAL_STM32_OSPEED_HIGHEST PAL_STM32_OSPEED_HIGH -  #ifndef EARLY_INIT_PERFORM_BOOTLOADER_JUMP  #    define EARLY_INIT_PERFORM_BOOTLOADER_JUMP TRUE  #endif diff --git a/platforms/chibios/boards/QMK_PROTON_C/configs/chconf.h b/platforms/chibios/boards/QMK_PROTON_C/configs/chconf.h index f812332960..cc10304a3f 100644 --- a/platforms/chibios/boards/QMK_PROTON_C/configs/chconf.h +++ b/platforms/chibios/boards/QMK_PROTON_C/configs/chconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -29,7 +29,27 @@  #define CHCONF_H  #define _CHIBIOS_RT_CONF_ -#define _CHIBIOS_RT_CONF_VER_6_1_ +#define _CHIBIOS_RT_CONF_VER_7_0_ + +/*===========================================================================*/ +/** + * @name System settings + * @{ + */ +/*===========================================================================*/ + +/** + * @brief   Handling of instances. + * @note    If enabled then threads assigned to various instances can + *          interact each other using the same synchronization objects. + *          If disabled then each OS instance is a separate world, no + *          direct interactions are handled by the OS. + */ +#if !defined(CH_CFG_SMP_MODE) +#define CH_CFG_SMP_MODE                     FALSE +#endif + +/** @} */  /*===========================================================================*/  /** @@ -161,6 +181,16 @@  #endif  /** + * @brief   Time Stamps APIs. + * @details If enabled then the time stamps APIs are included in the kernel. + * + * @note    The default is @p TRUE. + */ +#if !defined(CH_CFG_USE_TIMESTAMP) +#define CH_CFG_USE_TIMESTAMP                TRUE +#endif + +/**   * @brief   Threads registry APIs.   * @details If enabled then the registry APIs are included in the kernel.   * @@ -631,7 +661,7 @@   * @details User fields added to the end of the @p ch_system_t structure.   */  #define CH_CFG_SYSTEM_EXTRA_FIELDS                                          \ -  /* Add threads custom fields here.*/ +  /* Add system custom fields here.*/  /**   * @brief   System initialization hook. @@ -639,7 +669,23 @@   *          just before interrupts are enabled globally.   */  #define CH_CFG_SYSTEM_INIT_HOOK() {                                         \ -  /* Add threads initialization code here.*/                                \ +  /* Add system initialization code here.*/                                 \ +} + +/** + * @brief   OS instance structure extension. + * @details User fields added to the end of the @p os_instance_t structure. + */ +#define CH_CFG_OS_INSTANCE_EXTRA_FIELDS                                     \ +  /* Add OS instance custom fields here.*/ + +/** + * @brief   OS instance initialization hook. + * + * @param[in] oip       pointer to the @p os_instance_t structure + */ +#define CH_CFG_OS_INSTANCE_INIT_HOOK(oip) {                                 \ +  /* Add OS instance initialization code here.*/                            \  }  /** @@ -655,6 +701,8 @@   *   * @note    It is invoked from within @p _thread_init() and implicitly from all   *          the threads creation APIs. + * + * @param[in] tp        pointer to the @p thread_t structure   */  #define CH_CFG_THREAD_INIT_HOOK(tp) {                                       \    /* Add threads initialization code here.*/                                \ @@ -663,6 +711,8 @@  /**   * @brief   Threads finalization hook.   * @details User finalization code added to the @p chThdExit() API. + * + * @param[in] tp        pointer to the @p thread_t structure   */  #define CH_CFG_THREAD_EXIT_HOOK(tp) {                                       \    /* Add threads finalization code here.*/                                  \ @@ -671,6 +721,9 @@  /**   * @brief   Context switch hook.   * @details This hook is invoked just before switching between threads. + * + * @param[in] ntp       thread being switched in + * @param[in] otp       thread being switched out   */  #define CH_CFG_CONTEXT_SWITCH_HOOK(ntp, otp) {                              \    /* Context switch code here.*/                                            \ @@ -745,6 +798,14 @@    /* Trace code here.*/                                                     \  } +/** + * @brief   Runtime Faults Collection Unit hook. + * @details This hook is invoked each time new faults are collected and stored. + */ +#define CH_CFG_RUNTIME_FAULTS_HOOK(mask) {                                  \ +  /* Faults handling code here.*/                                           \ +} +  /** @} */  /*===========================================================================*/ diff --git a/platforms/chibios/boards/QMK_PROTON_C/configs/halconf.h b/platforms/chibios/boards/QMK_PROTON_C/configs/halconf.h index d7a639a6d0..8367328a04 100644 --- a/platforms/chibios/boards/QMK_PROTON_C/configs/halconf.h +++ b/platforms/chibios/boards/QMK_PROTON_C/configs/halconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -29,7 +29,7 @@  #define HALCONF_H  #define _CHIBIOS_HAL_CONF_ -#define _CHIBIOS_HAL_CONF_VER_7_1_ +#define _CHIBIOS_HAL_CONF_VER_8_0_  #include <mcuconf.h> @@ -416,6 +416,26 @@  #endif  /*===========================================================================*/ +/* SIO driver related settings.                                              */ +/*===========================================================================*/ + +/** + * @brief   Default bit rate. + * @details Configuration parameter, this is the baud rate selected for the + *          default configuration. + */ +#if !defined(SIO_DEFAULT_BITRATE) || defined(__DOXYGEN__) +#define SIO_DEFAULT_BITRATE                 38400 +#endif + +/** + * @brief   Support for thread synchronization API. + */ +#if !defined(SIO_USE_SYNCHRONIZATION) || defined(__DOXYGEN__) +#define SIO_USE_SYNCHRONIZATION             TRUE +#endif + +/*===========================================================================*/  /* SERIAL_USB driver related setting.                                        */  /*===========================================================================*/ @@ -451,11 +471,10 @@  #endif  /** - * @brief   Enables circular transfers APIs. - * @note    Disabling this option saves both code and data space. + * @brief   Inserts an assertion on function errors before returning.   */ -#if !defined(SPI_USE_CIRCULAR) || defined(__DOXYGEN__) -#define SPI_USE_CIRCULAR                    FALSE +#if !defined(SPI_USE_ASSERT_ON_ERROR) || defined(__DOXYGEN__) +#define SPI_USE_ASSERT_ON_ERROR             TRUE  #endif  /** diff --git a/platforms/chibios/boards/QMK_PROTON_C/configs/mcuconf.h b/platforms/chibios/boards/QMK_PROTON_C/configs/mcuconf.h index 4d7b586c08..cab4c29cf6 100644 --- a/platforms/chibios/boards/QMK_PROTON_C/configs/mcuconf.h +++ b/platforms/chibios/boards/QMK_PROTON_C/configs/mcuconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -186,7 +186,6 @@  /*   * PWM driver system settings.   */ -#define STM32_PWM_USE_ADVANCED              FALSE  #define STM32_PWM_USE_TIM1                  FALSE  #define STM32_PWM_USE_TIM2                  FALSE  #define STM32_PWM_USE_TIM3                  TRUE diff --git a/platforms/chibios/boards/common/configs/chconf.h b/platforms/chibios/boards/common/configs/chconf.h index 18ad609ca1..5db836e37c 100644 --- a/platforms/chibios/boards/common/configs/chconf.h +++ b/platforms/chibios/boards/common/configs/chconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -29,7 +29,27 @@  #define CHCONF_H  #define _CHIBIOS_RT_CONF_ -#define _CHIBIOS_RT_CONF_VER_6_1_ +#define _CHIBIOS_RT_CONF_VER_7_0_ + +/*===========================================================================*/ +/** + * @name System settings + * @{ + */ +/*===========================================================================*/ + +/** + * @brief   Handling of instances. + * @note    If enabled then threads assigned to various instances can + *          interact each other using the same synchronization objects. + *          If disabled then each OS instance is a separate world, no + *          direct interactions are handled by the OS. + */ +#if !defined(CH_CFG_SMP_MODE) +#define CH_CFG_SMP_MODE                     FALSE +#endif + +/** @} */  /*===========================================================================*/  /** @@ -161,6 +181,16 @@  #endif  /** + * @brief   Time Stamps APIs. + * @details If enabled then the time stamps APIs are included in the kernel. + * + * @note    The default is @p TRUE. + */ +#if !defined(CH_CFG_USE_TIMESTAMP) +#define CH_CFG_USE_TIMESTAMP                TRUE +#endif + +/**   * @brief   Threads registry APIs.   * @details If enabled then the registry APIs are included in the kernel.   * @@ -631,7 +661,7 @@   * @details User fields added to the end of the @p ch_system_t structure.   */  #define CH_CFG_SYSTEM_EXTRA_FIELDS                                          \ -  /* Add threads custom fields here.*/ +  /* Add system custom fields here.*/  /**   * @brief   System initialization hook. @@ -639,7 +669,23 @@   *          just before interrupts are enabled globally.   */  #define CH_CFG_SYSTEM_INIT_HOOK() {                                         \ -  /* Add threads initialization code here.*/                                \ +  /* Add system initialization code here.*/                                 \ +} + +/** + * @brief   OS instance structure extension. + * @details User fields added to the end of the @p os_instance_t structure. + */ +#define CH_CFG_OS_INSTANCE_EXTRA_FIELDS                                     \ +  /* Add OS instance custom fields here.*/ + +/** + * @brief   OS instance initialization hook. + * + * @param[in] oip       pointer to the @p os_instance_t structure + */ +#define CH_CFG_OS_INSTANCE_INIT_HOOK(oip) {                                 \ +  /* Add OS instance initialization code here.*/                            \  }  /** @@ -655,6 +701,8 @@   *   * @note    It is invoked from within @p _thread_init() and implicitly from all   *          the threads creation APIs. + * + * @param[in] tp        pointer to the @p thread_t structure   */  #define CH_CFG_THREAD_INIT_HOOK(tp) {                                       \    /* Add threads initialization code here.*/                                \ @@ -663,6 +711,8 @@  /**   * @brief   Threads finalization hook.   * @details User finalization code added to the @p chThdExit() API. + * + * @param[in] tp        pointer to the @p thread_t structure   */  #define CH_CFG_THREAD_EXIT_HOOK(tp) {                                       \    /* Add threads finalization code here.*/                                  \ @@ -671,6 +721,9 @@  /**   * @brief   Context switch hook.   * @details This hook is invoked just before switching between threads. + * + * @param[in] ntp       thread being switched in + * @param[in] otp       thread being switched out   */  #define CH_CFG_CONTEXT_SWITCH_HOOK(ntp, otp) {                              \    /* Context switch code here.*/                                            \ @@ -745,6 +798,14 @@    /* Trace code here.*/                                                     \  } +/** + * @brief   Runtime Faults Collection Unit hook. + * @details This hook is invoked each time new faults are collected and stored. + */ +#define CH_CFG_RUNTIME_FAULTS_HOOK(mask) {                                  \ +  /* Faults handling code here.*/                                           \ +} +  /** @} */  /*===========================================================================*/ diff --git a/platforms/chibios/boards/common/configs/halconf.h b/platforms/chibios/boards/common/configs/halconf.h index c80f67ee27..1805a77438 100644 --- a/platforms/chibios/boards/common/configs/halconf.h +++ b/platforms/chibios/boards/common/configs/halconf.h @@ -1,5 +1,5 @@  /* -    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio +    ChibiOS - Copyright (C) 2006..2020 Giovanni Di Sirio      Licensed under the Apache License, Version 2.0 (the "License");      you may not use this file except in compliance with the License. @@ -29,7 +29,7 @@  #define HALCONF_H  #define _CHIBIOS_HAL_CONF_ -#define _CHIBIOS_HAL_CONF_VER_7_1_ +#define _CHIBIOS_HAL_CONF_VER_8_0_  #include <mcuconf.h> @@ -416,6 +416,26 @@  #endif  /*===========================================================================*/ +/* SIO driver related settings.                                              */ +/*===========================================================================*/ + +/** + * @brief   Default bit rate. + * @details Configuration parameter, this is the baud rate selected for the + *          default configuration. + */ +#if !defined(SIO_DEFAULT_BITRATE) || defined(__DOXYGEN__) +#define SIO_DEFAULT_BITRATE                 38400 +#endif + +/** + * @brief   Support for thread synchronization API. + */ +#if !defined(SIO_USE_SYNCHRONIZATION) || defined(__DOXYGEN__) +#define SIO_USE_SYNCHRONIZATION             TRUE +#endif + +/*===========================================================================*/  /* SERIAL_USB driver related setting.                                        */  /*===========================================================================*/ @@ -451,11 +471,10 @@  #endif  /** - * @brief   Enables circular transfers APIs. - * @note    Disabling this option saves both code and data space. + * @brief   Inserts an assertion on function errors before returning.   */ -#if !defined(SPI_USE_CIRCULAR) || defined(__DOXYGEN__) -#define SPI_USE_CIRCULAR                    FALSE +#if !defined(SPI_USE_ASSERT_ON_ERROR) || defined(__DOXYGEN__) +#define SPI_USE_ASSERT_ON_ERROR             TRUE  #endif  /** diff --git a/platforms/chibios/drivers/ws2812_spi.c b/platforms/chibios/drivers/ws2812_spi.c index 76191db165..01d8148875 100644 --- a/platforms/chibios/drivers/ws2812_spi.c +++ b/platforms/chibios/drivers/ws2812_spi.c @@ -139,7 +139,33 @@ void ws2812_init(void) {  #endif // WS2812_SPI_SCK_PIN      // TODO: more dynamic baudrate -    static const SPIConfig spicfg = {WS2812_SPI_BUFFER_MODE, NULL, PAL_PORT(RGB_DI_PIN), PAL_PAD(RGB_DI_PIN), WS2812_SPI_DIVISOR_CR1_BR_X}; +    static const SPIConfig spicfg = { +#ifndef HAL_LLD_SELECT_SPI_V2 +// HAL_SPI_V1 +#    if SPI_SUPPORTS_CIRCULAR == TRUE +        WS2812_SPI_BUFFER_MODE, +#    endif +        NULL, // end_cb +        PAL_PORT(RGB_DI_PIN), +        PAL_PAD(RGB_DI_PIN), +        WS2812_SPI_DIVISOR_CR1_BR_X, +        0 +#else +    // HAL_SPI_V2 +#    if SPI_SUPPORTS_CIRCULAR == TRUE +        WS2812_SPI_BUFFER_MODE, +#    endif +#    if SPI_SUPPORTS_SLAVE_MODE == TRUE +        false, +#    endif +        NULL, // data_cb +        NULL, // error_cb +        PAL_PORT(RGB_DI_PIN), +        PAL_PAD(RGB_DI_PIN), +        WS2812_SPI_DIVISOR_CR1_BR_X, +        0 +#endif +    };      spiAcquireBus(&WS2812_SPI);     /* Acquire ownership of the bus.    */      spiStart(&WS2812_SPI, &spicfg); /* Setup transfer parameters.       */ diff --git a/platforms/chibios/flash.mk b/platforms/chibios/flash.mk index 6ee53172d2..a91ef2cf35 100644 --- a/platforms/chibios/flash.mk +++ b/platforms/chibios/flash.mk @@ -40,6 +40,18 @@ endef  dfu-util: $(BUILD_DIR)/$(TARGET).bin cpfirmware sizeafter  	$(call EXEC_DFU_UTIL) +define EXEC_UF2_UTIL_DEPLOY +	if ! $(UF2CONV) --deploy $(BUILD_DIR)/$(TARGET).uf2 2>/dev/null; then \ +		printf "$(MSG_BOOTLOADER_NOT_FOUND_QUICK_RETRY)" ;\ +		sleep $(BOOTLOADER_RETRY_TIME) ;\ +		while ! $(UF2CONV) --deploy $(BUILD_DIR)/$(TARGET).uf2  2>/dev/null; do \ +			printf "." ;\ +			sleep $(BOOTLOADER_RETRY_TIME) ;\ +		done ;\ +		printf "\n" ;\ +	fi +endef +  # TODO: Remove once ARM has a way to configure EECONFIG_HANDEDNESS  #       within the emulated eeprom via dfu-util or another tool  ifneq (,$(filter $(MAKECMDGOALS),dfu-util-split-left)) @@ -90,6 +102,8 @@ ifneq ($(strip $(PROGRAM_CMD)),)  	$(UNSYNC_OUTPUT_CMD) && $(PROGRAM_CMD)  else ifeq ($(strip $(BOOTLOADER)),kiibohd)  	$(UNSYNC_OUTPUT_CMD) && $(call EXEC_DFU_UTIL) +else ifeq ($(strip $(BOOTLOADER)),tinyuf2) +	$(UNSYNC_OUTPUT_CMD) && $(call EXEC_UF2_UTIL_DEPLOY)  else ifeq ($(strip $(MCU_FAMILY)),KINETIS)  	$(UNSYNC_OUTPUT_CMD) && $(call EXEC_TEENSY)  else ifeq ($(strip $(MCU_FAMILY)),MIMXRT1062) diff --git a/platforms/chibios/platform.mk b/platforms/chibios/platform.mk index 6fd1fd83f5..91dd0479bc 100644 --- a/platforms/chibios/platform.mk +++ b/platforms/chibios/platform.mk @@ -39,7 +39,6 @@ ifeq ($(strip $(MCU)), risc-v)      STARTUP_MK = $(CHIBIOS_CONTRIB)/os/common/startup/RISCV-ECLIC/compilers/GCC/mk/startup_$(MCU_STARTUP).mk      PORT_V = $(CHIBIOS_CONTRIB)/os/common/ports/RISCV-ECLIC/compilers/GCC/mk/port.mk      RULESPATH = $(CHIBIOS_CONTRIB)/os/common/startup/RISCV-ECLIC/compilers/GCC -    PLATFORM_MK = $(CHIBIOS_CONTRIB)/os/hal/ports/GD/GD32VF103/platform.mk  else      # ARM Support      CHIBIOS_PORT ?= @@ -82,10 +81,15 @@ ifeq ("$(PLATFORM_NAME)","")      PLATFORM_NAME = platform  endif +# If no MCU port name was specified, use the family instead +ifeq ("$(MCU_PORT_NAME)","") +    MCU_PORT_NAME = $(MCU_FAMILY) +endif +  ifeq ("$(wildcard $(PLATFORM_MK))","") -    PLATFORM_MK = $(CHIBIOS)/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES)/$(PLATFORM_NAME).mk +    PLATFORM_MK = $(CHIBIOS)/os/hal/ports/$(MCU_PORT_NAME)/$(MCU_SERIES)/$(PLATFORM_NAME).mk      ifeq ("$(wildcard $(PLATFORM_MK))","") -        PLATFORM_MK = $(CHIBIOS_CONTRIB)/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES)/$(PLATFORM_NAME).mk +        PLATFORM_MK = $(CHIBIOS_CONTRIB)/os/hal/ports/$(MCU_PORT_NAME)/$(MCU_SERIES)/$(PLATFORM_NAME).mk      endif  endif diff --git a/platforms/chibios/timer.c b/platforms/chibios/timer.c index e3bdfdcc37..5e01ea6372 100644 --- a/platforms/chibios/timer.c +++ b/platforms/chibios/timer.c @@ -40,7 +40,7 @@ static virtual_timer_t update_timer;  #    define UPDATE_INTERVAL (((sysinterval_t)1) << (CH_CFG_ST_RESOLUTION - 1))  // VT callback function to keep the overflow bits of the system tick counter updated. -static void update_fn(void *arg) { +static void update_fn(struct ch_virtual_timer *timer, void *arg) {      (void)arg;      chSysLockFromISR();      get_system_time_ticks(); diff --git a/platforms/chibios/wait.c b/platforms/chibios/wait.c index 56fd6ffcec..88cb5e6d54 100644 --- a/platforms/chibios/wait.c +++ b/platforms/chibios/wait.c @@ -31,7 +31,7 @@ void wait_us(uint16_t duration) {       * Only use this timer on the main thread;       * other threads need to use their own timer.       */ -    if (chThdGetSelfX() == &ch.mainthread && duration < (1ULL << (sizeof(gptcnt_t) * 8))) { +    if (chThdGetSelfX() == &(currcore->mainthread) && duration < (1ULL << (sizeof(gptcnt_t) * 8))) {          gptStart(&WAIT_US_TIMER, &gpt_cfg);          gptPolledDelay(&WAIT_US_TIMER, duration);      } else { diff --git a/platforms/pin_defs.h b/platforms/pin_defs.h index ea730138f2..341fe89b6e 100644 --- a/platforms/pin_defs.h +++ b/platforms/pin_defs.h @@ -18,6 +18,6 @@  // useful for direct pin mapping  #define NO_PIN (pin_t)(~0) -#if __has_include_next("pin_defs.h") -#    include_next "pin_defs.h" /* Include the platforms pin_defs.h */ +#if __has_include("_pin_defs.h") +#    include "_pin_defs.h" /* Include the platforms pin defs */  #endif | 
