kolibrios-gitea/contrib/C_Layer/libguic_kolibri/kolibri_debug.h
Serhii Sakhno 5caf0c04c7 kolibri_debug.h: fdebug_board_write_str rename to debug_board_printf
git-svn-id: svn://kolibrios.org@6399 a494cfbc-eb01-0410-851d-a64ba20cac60
2016-04-13 06:36:36 +00:00

37 lines
768 B
C

#ifndef KOLIBRI_DEBUG_H
#define KOLIBRI_DEBUG_H
#include <_ansi.h>
#include <reent.h>
#include <stdio.h>
#include <stdarg.h>
/* Write a printf() like function (variable argument list) for
writing to debug board */
inline void debug_board_write_byte(const char ch){
__asm__ __volatile__(
"int $0x40"
:
:"a"(63), "b"(1), "c"(ch));
}
//added noninline because incofortabre stepping in in debugger
void __attribute__ ((noinline)) debug_board_write_str(const char* str){
while(*str)
debug_board_write_byte(*str++);
}
void debug_board_printf(const char *format,...)
{
va_list ap;
char log_board[300];
va_start (ap, format);
vsprintf(log_board, format, ap);
va_end(ap);
debug_board_write_str(log_board);
}
#endif /* KOLIBRI_DEBUG_H */