ATTiny841 RFM69 SPI transfer hangs

Hello & thanks in advance for any help. I am having a problem using the RFM69HCW module attached to a ATtiny841. I think the problem is with the SPI library/ATTinyCore. I have successfully used the same code with ATmega328PB and ESP8266 processors. I have narrowed the code down as much as possible to illustrate the issue.
When all code using SPI transfers is commented out, the code works as expected as evidenced by the action on the "scope" pin. However as soon as any SPI action is called, the code hangs; no action on the scope pin and no action on any SPI pin.
I am using ATTinyCore/Konde v1.4.1, RFM_LowPowerLab v1.5.2, Arduino IDE v1.8.13. The RFM69 module is connected to PA4 to PA6 (SCK, MISO, MOSI, NSS) but not connected for this test (same results if connected). Thanks.

// ATtiny841, chip 841, clock 8MHz internal<4.5V, bootloader UART0
// with optiboot - 71% flash, 66% RAM, requires millis()
// use print(F("xx")) 72% flash, 58% RAM

#include <RFM69.h>
#include <SPI.h>

#define NETWORKID     0           // Must be the same for all nodes
#define MYNODEID      22          // My node ID
#define TONODEID      99          // Destination node ID
#define FREQUENCY     RF69_915MHZ // RFM69 frequency
#define scopePin      PIN_PB0     // debug

RFM69 radio;                      // Create a library object

// ----------------------- Setup -------------------------------
void setup() {
  Serial.begin(9600);             // 115200 works also
  pinMode(scopePin, OUTPUT);
  delay(200);  
  Serial.println("Start");
  radio.initialize(FREQUENCY, MYNODEID, NETWORKID);  // Initialize the RFM69HCW:
//  radio.setHighPower();           // Always for RFM69HCW
  Serial.println("ok");
}

// ------------------------ Main ----------------------------
void loop() {
  scope();
//  if (radio.receiveDone()) {            // incoming msg complete
//    Serial.print(F("received from "));  // print out the data received
//    Serial.print(radio.SENDERID, DEC);  // from ID
//    Serial.print(F(", msg ["));         // DATA array, DATALEN bytes in size:
//    for (byte i = 0; i < radio.DATALEN; i++) Serial.print((char)radio.DATA[i]);
//    Serial.print("], RSSI ");           // RSSI smaller stronger
//    Serial.println(radio.RSSI);
//  }
}

void scope() {
  delay(1);
  digitalWrite(scopePin, HIGH);
  delay(1);
  digitalWrite(scopePin, LOW);
}

This topic was automatically closed 180 days after the last reply. New replies are no longer allowed.