diff --git a/include/arch/lora32u4ii/driver/spi.h b/include/arch/lora32u4ii/driver/spi.h
new file mode 100644
index 0000000000000000000000000000000000000000..6377fe9c1ede20fb7b215a193c0965c9828a40bc
--- /dev/null
+++ b/include/arch/lora32u4ii/driver/spi.h
@@ -0,0 +1,15 @@
+#pragma once
+
+class SPI {
+	private:
+		SPI(const SPI &copy);
+
+	public:
+		SPI () {}
+		signed char setup();
+		signed char xmit(
+				unsigned char tx_len, unsigned char *tx_buf,
+				unsigned char rx_len, unsigned char *rx_buf);
+};
+
+extern SPI spi;
diff --git a/src/arch/lora32u4ii/Kconfig b/src/arch/lora32u4ii/Kconfig
index eb857809612253b02ba097f04146a1cbecbb82b2..8a59fa6ec2bb1db19dafd2fa0823a3ffd8af7069 100644
--- a/src/arch/lora32u4ii/Kconfig
+++ b/src/arch/lora32u4ii/Kconfig
@@ -14,6 +14,10 @@ config arch_lora32u4ii_driver_adc
 bool "ADC (Analog-Digital-Converter)"
 select meta_driver_adc
 
+config arch_lora32u4ii_driver_spi
+bool "SPI"
+select meta_driver_spi
+
 config arch_lora32u4ii_driver_uptime
 bool "Uptime Counter"
 select meta_driver_uptime
diff --git a/src/arch/lora32u4ii/Makefile.inc b/src/arch/lora32u4ii/Makefile.inc
index 3aeefa8cdd7ebe3b95a746e1aef5063f1e5b283e..f14bc8c975adcaac487a3b5c6db6cccab9b1f1c3 100644
--- a/src/arch/lora32u4ii/Makefile.inc
+++ b/src/arch/lora32u4ii/Makefile.inc
@@ -48,12 +48,20 @@ ifneq ($(findstring adc,${arch_drivers}), )
 	CONFIG_arch_lora32u4ii_driver_adc = y
 endif
 
+ifneq ($(findstring spi,${arch_drivers}), )
+	CONFIG_arch_lora32u4ii_driver_spi = y
+endif
+
 # Kconfig driver selection
 
 ifdef CONFIG_arch_lora32u4ii_driver_adc
 	CXX_TARGETS += src/arch/lora32u4ii/driver/adc.cc
 endif
 
+ifdef CONFIG_arch_lora32u4ii_driver_spi
+	CXX_TARGETS += src/arch/lora32u4ii/driver/spi.cc
+endif
+
 ifdef CONFIG_arch_lora32u4ii_driver_uptime
 	COMMON_FLAGS += -DTIMER_S
 	CXX_TARGETS += src/arch/lora32u4ii/driver/uptime.cc
diff --git a/src/arch/lora32u4ii/driver/spi.cc b/src/arch/lora32u4ii/driver/spi.cc
new file mode 100644
index 0000000000000000000000000000000000000000..f7cc29e15fcc2f4a1041d5dd6ec029baff6e8bbb
--- /dev/null
+++ b/src/arch/lora32u4ii/driver/spi.cc
@@ -0,0 +1,39 @@
+#include "driver/spi.h"
+#include "driver/gpio.h"
+#include "arch.h"
+#include <avr/io.h>
+
+signed char SPI::setup()
+{
+	// configure SS as output to avoid unintened switches to slave mode
+	gpio.output(GPIO::pb0, 0);
+	// MISO is automatically configured as input
+	// Configure SCK and MOSI as output
+	DDRB |= _BV(PB2) | _BV(PB1);
+	// up to 2 MHz SPI clock
+	SPCR = _BV(SPE) | _BV(MSTR) | _BV(SPR0);
+}
+
+signed char SPI::xmit(
+		unsigned char tx_len, unsigned char *tx_buf,
+		unsigned char rx_len, unsigned char *rx_buf)
+{
+	unsigned char i = 0;
+
+	while ((i < tx_len) || (i < rx_len)) {
+		if (i < tx_len) {
+			SPDR = tx_buf[i];
+		} else {
+			SPDR = 0;
+		}
+		arch.delay_ms(1);
+		while (!(SPSR & _BV(SPIF))) ;
+		if (i < rx_len) {
+			rx_buf[i] = SPDR;
+		}
+		i++;
+	}
+	return 0;
+}
+
+SPI spi;