From 5b4af5a4522367fd3bb4a7dc36b24afe038280e8 Mon Sep 17 00:00:00 2001 From: Spence Konde Date: Tue, 22 Mar 2022 20:31:21 -0400 Subject: [PATCH] Last change before release --- ChangeLog.md | 2 + megaavr/cores/megatinycore/core_devices.h | 9 +++- megaavr/libraries/Logic/README.md | 60 +++++++++++------------ megaavr/libraries/SPI/src/SPI.cpp | 2 +- 4 files changed, 41 insertions(+), 32 deletions(-) diff --git a/ChangeLog.md b/ChangeLog.md index 1ca2b9e5..668c138e 100644 --- a/ChangeLog.md +++ b/ChangeLog.md @@ -6,6 +6,7 @@ Changes listed here are checked in to GitHub ("master" branch unless specificall ### Planned 2.5.11 * **CRITICAL BUGFIX** - I finally saw the bug in my attachInterrupt implementation. I had a operands of a load backwards. (#651) +* **CRITICAL BUGFIX** - Apply changes from DxCore to SPI library where needed for new attachInterrupt behavior. * Make it possible to have applications that use our USERSIG library be code compatible with DxCore by providing do-nothing functions in place of dxcore's flush(), pending() functions, add erase() and make everything match the return types and report success. * Documentation improvements in a few areas. * Based on feedback, removed emulation of classicAVR pinMode() calls as regards the state of the PORTx.OUT register. @@ -13,6 +14,7 @@ Changes listed here are checked in to GitHub ("master" branch unless specificall * Fix output asset names for Microchip board definitions. * Preempt compatibility problems with libraries that assume a HardwareSerial.h file. * Improve user experience for people using updated compilers. Makes bit of a mess out of uart_constants.h though. +* Fix bugs with compatibility in names of constants associated with no change in function. Sigh. ### Ongoing * Port enhanced documentation from DxCore. diff --git a/megaavr/cores/megatinycore/core_devices.h b/megaavr/cores/megatinycore/core_devices.h index ef6d4c27..bec59f36 100644 --- a/megaavr/cores/megatinycore/core_devices.h +++ b/megaavr/cores/megatinycore/core_devices.h @@ -369,9 +369,16 @@ #define TCA_SINGLE_EVACT_CNT_ANYEDGE_gc TCA_SINGLE_EVACTA_CNT_ANYEDGE_gc #define TCA_SINGLE_EVACT_CNT_HIGHLVL_gc TCA_SINGLE_EVACTA_CNT_HIGHLVL_gc #define TCA_SINGLE_EVACT_UPDOWN_gc TCA_SINGLE_EVACTA_UPDOWN_gc + #define TCB_CLKSEL_CLKDIV1_gc TCB_CLKSEL_DIV1_gc + #define TCB_CLKSEL_CLKDIV2_gc TCB_CLKSEL_DIV2_gc + #define TCB_CLKSEL_CLKTCA_gc TCB_CLKSEL_TCA0_gc +#else + #define TCB_CLKSEL_DIV1_gc TCB_CLKSEL_CLKDIV1_gc + #define TCB_CLKSEL_DIV2_gc TCB_CLKSEL_CLKDIV2_gc + #define TCB_CLKSEL_TCA0_gc TCB_CLKSEL_CLKTCA_gc + #define TCB_CLKSEL_EVENT_gc ({badArg("This processor does not support TCB count on event mode. Only Dx, Ex, and 2-series tiny support that");}) #endif - /* Make sure we error out quickly if told to use an RTC timing option that isn't available. */ #if (defined(MILLIS_USE_TIMERRTC_XTAL) || defined(MILLIS_USE_TIMERRTC_XOSC)) #if (MEGATINYCORE_SERIES == 0 || defined(__AVR_ATtinyxy2__)) diff --git a/megaavr/libraries/Logic/README.md b/megaavr/libraries/Logic/README.md index aefc07a6..a6b4558a 100644 --- a/megaavr/libraries/Logic/README.md +++ b/megaavr/libraries/Logic/README.md @@ -12,7 +12,7 @@ More information about CCL can be found in the [Microchip Application Note TB321 These objects expose **all** configuration options as properties, described below, and provide methods to apply those settings, attach interrupts (2-series only) and enable and disable the CCL in general. ### Pin availability and Quick Reference -This was simpler with 0/1-series (22 i/o pins, 10 CCL functions, none stacked onto the same pins), but with 2-series, 20 different CCL functions, crammed into just 22 GPIO pins, two of which have one blocks' input and one of the outputs for another. The ones with no inputs on lower pincount parts are more useful than one might expect; advanced use cases will often use mostly internal inputs - and the event system can always be used to get pin input in anyway - albeit at a cost of an event channel. +This was simpler with 0/1-series (22 i/o pins, 10 CCL functions, none stacked onto the same pins), but with 2-series, 20 different CCL functions, crammed into just 22 GPIO pins, two of which have one blocks' input and one of the outputs for another. The ones with no inputs on lower pincount parts are more useful than one might expect; advanced use cases will often use mostly internal inputs - and the event system can always be used to get pin input in anyway - albeit at a cost of an event channel. If you do not require pin inputs, these should be used in preference to the logic blocks that do have them all else veing equa;l Logic Block | IN0-2 | OUT | 8pin | ALT OUT | Availability | ------------|---------|-----|------|---------|--------------| @@ -24,42 +24,41 @@ Logic3 | PC0-PC2 | PC4 | --- | PA5 | 2-series | * Inputs are always in consecutive order counting by bit position (not physical order). -* All logic blocks present always have at least one output pin +* All logic blocks present *on tinyAVR* always have an output pin, but may not have input pins. * `Logic2` and `Logic3` are present only on the 2-series. -Logic Block | 8-pin | 14-pin | 20-pin | 24-pin | -------------|-------------|---------------|---------------|---------------| -Logic0 IN | IN0 IS UPDI | IN0 IS UPDI | IN0 IS UPDI | IN0 IS UPDI | -Logic0 OUT | NO ALT OUT0 | NO ALT OUT0 | YES, BOTH | YES, BOTH | -Logic1 IN | NO INPUTS | NO INPUTS | IN0 ONLY | YES, ALL | -Logic1 OUT | NO ALT OUT1 | NO ALT OUT1 | YES, BOTH | YES, BOTH | -Logic2 IN | N/A | YES, ALL | YES, ALL | YES, ALL | -Logic2 OUT | N/A | NO ALT OUT2 | NO ALT OUT2 | YES, BOTH | -Logic3 IN | N/A | NO INPUTS | YES, ALL | YES, ALL | -Logic3 OUT | N/A | ALT OUT3 ONLY | ALT OUT3 ONLY | YES, BOTH | +Logic Block | 8-pin | 14-pin | 20-pin | 24-pin | +------------|---------------|---------------|---------------|---------------| +Logic0 IN | IN0 is UPDI | IN0 is UPDI | IN0 is UPDI | IN0 is UPDI | +Logic0 OUT | No alt output | No alt output | Yes, both | Yes, both | +Logic1 IN | None | None | IN0 only | Yes, all | +Logic1 OUT | No alt output | No alt output | Yes, both | Yes, both | +Logic2 IN | Not present | Yes, all | Yes, all | Yes, all | +Logic2 OUT | Not present | No alt output | No alt output | Yes, both | +Logic3 IN | Not present | None | Yes, all | Yes, all | +Logic3 OUT | Not present | Only alt out | Only alt out | Yes, both | ### Overhead -On the 0/1-series, the overhead is approximately 546 bytes of flash and 26 bytes of RAM. -On the 2-series, with twice as many LUTs, it is much larger: 984 bytes and 60b RAM. -This is farily small for most parts - it cannot be ignored on a 4k part, particularly not a 4k 2-series, but it it isn't an unreasonable amount of flash for the parts most people will be using. A future update will add a second slihtly modified version which removes attachInterrupt to permit manual implementation of the CCL interrupt, as any "attachInterrupt" scheme will always perform poorly, with an overhead of over 50 clock cycles in the ISR because of the call to a function that can't be inlined because it is set at runtime. - -Writing a constant value to 4 registers (the minimum plausible needed to configure a LUT) for 2 or 4 LUTs requires 56 or 112 bytes, respectively. +* On the 0/1-series, the overhead is approximately 546 bytes of flash and 26 bytes of RAM. +* On the 2-series, with twice as many LUTs, it is much larger: 984 bytes and 60b RAM. +* This is farily small for 16/32k parts - it cannot be ignored on a 4k part, particularly not a 4k 2-series, but it it isn't an unreasonable amount of flash for the parts most people will be using. A future update will add a second slihtly modified version which removes attachInterrupt to permit manual implementation of the CCL interrupt, as any "attachInterrupt" scheme will always perform miserably (it is inherrent to calling a non-inlinable function on an AVR from within an ISR, with an overhead of over 50 clock cycles in the ISR and because the interrupt pointer is set at runtime, it can never be inlined. +* Writing a constant value to 4 registers (the minimum plausible needed to configure a LUT) for 2 or 4 LUTs requires 56 or 112 bytes, respectively. ## Logic class overview -| Property | namespace or type | Function | -|-------------|-----------------------------|---------------------------------------------| -| enable | bool | Enable or disable logic block | -| input0 | in:: | Selects input 0 | -| input1 | in:: | Selects input 1 | -| input2 | in:: | Selects input 2 | -| output | out:: | 'enable'/'disable' output pin | -| output_swap | out:: | 'no_swap/'pin_swap' use alt output pin | -| filter | filter:: | 'filter'/'sync' or 'disable' filter | -| edgedetect | edgedetect:: | 'enable'/'disable' edge detect mode | -| sequencer | sequencer:: | selects the sequecer, even #'ed blocks only | -| clocksource | clocksource:: | select clock source, if not async. | -| truth | uint8_t | truth table | +| Property | namespace or type | Function | +|-------------|---------------------|----------------------------------------------| +| enable | bool | Enable or disable logic block | +| input0 | in:: | Selects input 0 | +| input1 | in:: | Selects input 1 | +| input2 | in:: | Selects input 2 | +| output | out:: | 'enable'/'disable' output pin | +| output_swap | out:: | 'no_swap/'pin_swap' use alt output pin | +| filter | filter:: | 'filter'/'sync' or 'disable' filter | +| edgedetect | edgedetect:: | 'enable'/'disable' edge detect mode | +| sequencer | sequencer:: | selects the sequecer, even #'ed blocks only | +| clocksource | clocksource:: | select clock source, if not async. | +| truth | uint8_t | truth table | | Methods | Function |---------------------|-----------------------------------------------------------------------------| @@ -338,6 +337,7 @@ Logic::stop(); // Stop CCL Method for enabling interrupts for a specific block. Valid arguments for the third parameters are `RISING`, `FALLING` and `CHANGE`. This method isn't available on tinyAVR 0/1-series as these parts cannot generate an interrupt from the CCL blocks. +All forms of attachInterrupt, everywhere, are fundamentally evil, because they add a several microsecond overheead to the ISR simply because there is a call to a non-inlinable function; #### Usage ```c++ diff --git a/megaavr/libraries/SPI/src/SPI.cpp b/megaavr/libraries/SPI/src/SPI.cpp index b309820c..7ffe49f9 100644 --- a/megaavr/libraries/SPI/src/SPI.cpp +++ b/megaavr/libraries/SPI/src/SPI.cpp @@ -303,7 +303,7 @@ void SPIClass::notUsingInterrupt(uint8_t interruptNumber) { void SPIClass::beginTransaction(SPISettings settings) { if (interruptMode != SPI_IMODE_NONE) { - old_sreg=SREG; + old_sreg = SREG; cli(); // NoInterrupts(); } in_transaction = 1;