mirror of
https://github.com/hoglet67/AtomBusMon.git
synced 2025-01-01 17:31:52 +00:00
Firmware: cleaned up status.c
Change-Id: I59a54b89cf3eb701a10953f4a4450ee0c64b862c
This commit is contained in:
parent
f841079548
commit
b28e49dbd9
@ -8,118 +8,23 @@
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <avr/interrupt.h>
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <ctype.h>
|
#include <stdlib.h>
|
||||||
#include "terminalcodes.h"
|
#include "terminalcodes.h"
|
||||||
#include "status.h"
|
#include "status.h"
|
||||||
|
|
||||||
|
|
||||||
/********************************************************
|
|
||||||
* Simple string logger, as log0 is expensive
|
|
||||||
********************************************************/
|
|
||||||
|
|
||||||
void logc(char c) {
|
|
||||||
Serial_TxByte0(c);
|
|
||||||
if (c == '\n') {
|
|
||||||
Serial_TxByte0('\r');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void logs(const char *s) {
|
|
||||||
while (*s) {
|
|
||||||
logc(*s++);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void logpgmstr(const char *s) {
|
|
||||||
char c;
|
|
||||||
do {
|
|
||||||
c = pgm_read_byte(s++);
|
|
||||||
if (c) {
|
|
||||||
logc(c);
|
|
||||||
}
|
|
||||||
} while (c);
|
|
||||||
}
|
|
||||||
|
|
||||||
char hex1(uint8_t i) {
|
|
||||||
i &= 0x0f;
|
|
||||||
if (i < 10) {
|
|
||||||
i += '0';
|
|
||||||
} else {
|
|
||||||
i += ('A' - 10);
|
|
||||||
}
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
|
|
||||||
void loghex1(uint8_t i) {
|
|
||||||
logc(hex1(i));
|
|
||||||
}
|
|
||||||
|
|
||||||
void loghex2(uint8_t i) {
|
|
||||||
loghex1(i >> 4);
|
|
||||||
loghex1(i);
|
|
||||||
}
|
|
||||||
|
|
||||||
void loghex4(uint16_t i) {
|
|
||||||
loghex2(i >> 8);
|
|
||||||
loghex2(i);
|
|
||||||
}
|
|
||||||
|
|
||||||
char *strfill(char *buffer, char c, uint8_t i) {
|
|
||||||
while (i-- > 0) {
|
|
||||||
*buffer++ = c;
|
|
||||||
}
|
|
||||||
return buffer;
|
|
||||||
}
|
|
||||||
|
|
||||||
char *strhex1(char *buffer, uint8_t i) {
|
|
||||||
*buffer++ = hex1(i);
|
|
||||||
return buffer;
|
|
||||||
}
|
|
||||||
|
|
||||||
char *strhex2(char *buffer, uint8_t i) {
|
|
||||||
buffer = strhex1(buffer, i >> 4);
|
|
||||||
buffer = strhex1(buffer, i);
|
|
||||||
return buffer;
|
|
||||||
}
|
|
||||||
|
|
||||||
char *strhex4(char *buffer, uint16_t i) {
|
|
||||||
buffer = strhex2(buffer, i >> 8);
|
|
||||||
buffer = strhex2(buffer, i);
|
|
||||||
return buffer;
|
|
||||||
}
|
|
||||||
|
|
||||||
//void loglong(long i) {
|
|
||||||
// char buffer[16];
|
|
||||||
// // ltoa adds 176 bytes
|
|
||||||
// logs(ltoa(i, buffer, 10));
|
|
||||||
//}
|
|
||||||
//
|
|
||||||
//void logint(int i) {
|
|
||||||
// char buffer[16];
|
|
||||||
// // itoa adds 176 bytes
|
|
||||||
// logs(itoa(i, buffer, 10));
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef SERIAL_STATUS
|
|
||||||
|
|
||||||
static int StdioSerial_TxByte0(char DataByte, FILE *Stream);
|
static int StdioSerial_TxByte0(char DataByte, FILE *Stream);
|
||||||
|
|
||||||
FILE ser0stream = FDEV_SETUP_STREAM(StdioSerial_TxByte0,NULL,_FDEV_SETUP_WRITE);
|
FILE ser0stream = FDEV_SETUP_STREAM(StdioSerial_TxByte0,NULL,_FDEV_SETUP_WRITE);
|
||||||
|
|
||||||
void StdioSerial_TxByte(char DataByte)
|
void StdioSerial_TxByte(char DataByte)
|
||||||
{
|
{
|
||||||
#ifdef COOKED_SERIAL
|
if((DataByte=='\r') || (DataByte=='\n')) {
|
||||||
if((DataByte=='\r') || (DataByte=='\n'))
|
Serial_TxByte0('\r');
|
||||||
{
|
Serial_TxByte0('\n');
|
||||||
Serial_TxByte0('\r');
|
} else {
|
||||||
Serial_TxByte0('\n');
|
Serial_TxByte0(DataByte);
|
||||||
}
|
}
|
||||||
else
|
|
||||||
#endif
|
|
||||||
Serial_TxByte0(DataByte);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int StdioSerial_TxByte0(char DataByte, FILE *Stream)
|
int StdioSerial_TxByte0(char DataByte, FILE *Stream)
|
||||||
@ -199,4 +104,94 @@ void Serial_Init(const uint32_t BaudRate0)
|
|||||||
cls();
|
cls();
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
/********************************************************
|
||||||
|
* Simple string logger, as log0 is expensive
|
||||||
|
********************************************************/
|
||||||
|
|
||||||
|
void logc(char c) {
|
||||||
|
StdioSerial_TxByte(c);
|
||||||
|
}
|
||||||
|
|
||||||
|
void logs(const char *s) {
|
||||||
|
while (*s) {
|
||||||
|
logc(*s++);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void logpgmstr(const char *s) {
|
||||||
|
char c;
|
||||||
|
do {
|
||||||
|
c = pgm_read_byte(s++);
|
||||||
|
if (c) {
|
||||||
|
logc(c);
|
||||||
|
}
|
||||||
|
} while (c);
|
||||||
|
}
|
||||||
|
|
||||||
|
char hex1(uint8_t i) {
|
||||||
|
i &= 0x0f;
|
||||||
|
if (i < 10) {
|
||||||
|
i += '0';
|
||||||
|
} else {
|
||||||
|
i += ('A' - 10);
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
|
void loghex1(uint8_t i) {
|
||||||
|
logc(hex1(i));
|
||||||
|
}
|
||||||
|
|
||||||
|
void loghex2(uint8_t i) {
|
||||||
|
loghex1(i >> 4);
|
||||||
|
loghex1(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
void loghex4(uint16_t i) {
|
||||||
|
loghex2(i >> 8);
|
||||||
|
loghex2(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
void logint(int i) {
|
||||||
|
char buffer[16];
|
||||||
|
strint(buffer, i);
|
||||||
|
logs(buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
void loglong(long i) {
|
||||||
|
char buffer[16];
|
||||||
|
strlong(buffer, i);
|
||||||
|
logs(buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *strfill(char *buffer, char c, uint8_t i) {
|
||||||
|
while (i-- > 0) {
|
||||||
|
*buffer++ = c;
|
||||||
|
}
|
||||||
|
return buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *strhex1(char *buffer, uint8_t i) {
|
||||||
|
*buffer++ = hex1(i);
|
||||||
|
return buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *strhex2(char *buffer, uint8_t i) {
|
||||||
|
buffer = strhex1(buffer, i >> 4);
|
||||||
|
buffer = strhex1(buffer, i);
|
||||||
|
return buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *strhex4(char *buffer, uint16_t i) {
|
||||||
|
buffer = strhex2(buffer, i >> 8);
|
||||||
|
buffer = strhex2(buffer, i);
|
||||||
|
return buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *strint(char *buffer, int i) {
|
||||||
|
return itoa(i, buffer, 10);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *strlong(char *buffer, long i) {
|
||||||
|
return ltoa(i, buffer, 10);
|
||||||
|
}
|
||||||
|
@ -34,20 +34,16 @@ void logpgmstr(const char *s);
|
|||||||
void loghex1(uint8_t i);
|
void loghex1(uint8_t i);
|
||||||
void loghex2(uint8_t i);
|
void loghex2(uint8_t i);
|
||||||
void loghex4(uint16_t i);
|
void loghex4(uint16_t i);
|
||||||
|
void logint(int i);
|
||||||
|
void loglong(long i);
|
||||||
char *strfill(char *buffer, char c, uint8_t i);
|
char *strfill(char *buffer, char c, uint8_t i);
|
||||||
char *strhex1(char *buffer, uint8_t i);
|
char *strhex1(char *buffer, uint8_t i);
|
||||||
char *strhex2(char *buffer, uint8_t i);
|
char *strhex2(char *buffer, uint8_t i);
|
||||||
char *strhex4(char *buffer, uint16_t i);
|
char *strhex4(char *buffer, uint16_t i);
|
||||||
|
char *strint(char *buffer, int i);
|
||||||
|
char *strlong(char *buffer, long i);
|
||||||
|
|
||||||
//void loglong(long i);
|
|
||||||
//void logint(int i);
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef SERIAL_STATUS
|
|
||||||
#define log0(format,...) fprintf_P(&ser0stream,PSTR(format),##__VA_ARGS__)
|
#define log0(format,...) fprintf_P(&ser0stream,PSTR(format),##__VA_ARGS__)
|
||||||
#else
|
|
||||||
#define log0(format,...)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// For stdio
|
// For stdio
|
||||||
|
@ -18,7 +18,7 @@ OBJCOPY=avr-objcopy
|
|||||||
|
|
||||||
PROG = avr_progmem
|
PROG = avr_progmem
|
||||||
|
|
||||||
CFLAGS=$(CPU_CFLAGS) -DF_CPU=${F_CPU}UL -DSERIAL_STATUS -DCOOKED_SERIAL -DNOUSART1 -mmcu=$(MCU) -Wall -Os -mcall-prologues
|
CFLAGS=$(CPU_CFLAGS) -DF_CPU=${F_CPU}UL -mmcu=$(MCU) -Wall -Os -mcall-prologues
|
||||||
|
|
||||||
OBJECTS=AtomBusMon.o status.o $(CPU_OBJECTS)
|
OBJECTS=AtomBusMon.o status.o $(CPU_OBJECTS)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user