summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/arch/lora32u4ii/driver/stdout.h2
-rw-r--r--src/arch/lora32u4ii/driver/stdout.cc12
2 files changed, 13 insertions, 1 deletions
diff --git a/include/arch/lora32u4ii/driver/stdout.h b/include/arch/lora32u4ii/driver/stdout.h
index 2eb669d..e9f0411 100644
--- a/include/arch/lora32u4ii/driver/stdout.h
+++ b/include/arch/lora32u4ii/driver/stdout.h
@@ -1,6 +1,7 @@
#ifndef STANDARDOUTPUT_H
#define STANDARDOUTPUT_H
+#include <avr/pgmspace.h>
#include "object/outputstream.h"
class StandardOutput : public OutputStream {
@@ -12,6 +13,7 @@ class StandardOutput : public OutputStream {
void setup();
virtual void put(char c) override;
+ OutputStream & pprint(const char *text);
};
extern StandardOutput kout;
diff --git a/src/arch/lora32u4ii/driver/stdout.cc b/src/arch/lora32u4ii/driver/stdout.cc
index afe6ff8..ee45a43 100644
--- a/src/arch/lora32u4ii/driver/stdout.cc
+++ b/src/arch/lora32u4ii/driver/stdout.cc
@@ -1,6 +1,5 @@
#include "driver/stdout.h"
#include <avr/io.h>
-#include <avr/interrupt.h>
#ifndef BAUD
#define BAUD 9600UL
@@ -24,6 +23,17 @@ void StandardOutput::setup()
//UCSR1D = 0;
}
+OutputStream & StandardOutput::pprint(const char *text)
+{
+ PGM_P p = reinterpret_cast<PGM_P>(text);
+ char c;
+ while ((c = pgm_read_byte(p++))) {
+ put(c);
+ }
+ return *this;
+}
+
+
void StandardOutput::put(char c)
{
while (!(UCSR1A & _BV(UDRE1)));