mirror of
https://github.com/esp8266/Arduino.git
synced 2025-04-19 23:22:16 +03:00
Add typedef for putc1, fn_putc1_t. (#6550)
* Add typedef for putc1, fn_putc1_t. Replaced relevant usage of `(void *)` with `fn_putc1_t`. Correct usage of `ets_putc()`, returning 0, in libc_replacement.cpp This PR assumes PR https://github.com/esp8266/Arduino/pull/6489#issue-315018841 has merged and removes `uart_buff_switch` from `umm_performance.cpp` Updated method of defining `_rom_putc1` to be more acceptable (I hope) to the new compiler. * Use PROVIDE to expose ROM function entry point, ets_uart_putc1. Added comments to ets_putc() and ets_uart_putc1() to explain their differences. Change prototype of ets_putc() to conform with fp_putc_t. Updated _isr_safe_printf_P to use new definition, ets_uart_putc1.
This commit is contained in:
parent
ff1e8e92d1
commit
831d6431bc
@ -108,8 +108,7 @@ void __wrap_system_restart_local() {
|
|||||||
else
|
else
|
||||||
rst_info.reason = s_user_reset_reason;
|
rst_info.reason = s_user_reset_reason;
|
||||||
|
|
||||||
// TODO: ets_install_putc1 definition is wrong in ets_sys.h, need cast
|
ets_install_putc1(&uart_write_char_d);
|
||||||
ets_install_putc1((void *)&uart_write_char_d);
|
|
||||||
|
|
||||||
if (s_panic_line) {
|
if (s_panic_line) {
|
||||||
ets_printf_P(PSTR("\nPanic %S:%d %S"), s_panic_file, s_panic_line, s_panic_func);
|
ets_printf_P(PSTR("\nPanic %S:%d %S"), s_panic_file, s_panic_line, s_panic_func);
|
||||||
|
@ -100,7 +100,8 @@ int ICACHE_RAM_ATTR _putc_r(struct _reent* r, int c, FILE* file) __attribute__((
|
|||||||
int ICACHE_RAM_ATTR _putc_r(struct _reent* r, int c, FILE* file) {
|
int ICACHE_RAM_ATTR _putc_r(struct _reent* r, int c, FILE* file) {
|
||||||
(void) r;
|
(void) r;
|
||||||
if (file->_file == STDOUT_FILENO) {
|
if (file->_file == STDOUT_FILENO) {
|
||||||
return ets_putc(c);
|
ets_putc(c);
|
||||||
|
return c;
|
||||||
}
|
}
|
||||||
return EOF;
|
return EOF;
|
||||||
}
|
}
|
||||||
|
@ -899,7 +899,7 @@ void
|
|||||||
uart_set_debug(int uart_nr)
|
uart_set_debug(int uart_nr)
|
||||||
{
|
{
|
||||||
s_uart_debug_nr = uart_nr;
|
s_uart_debug_nr = uart_nr;
|
||||||
void (*func)(char) = NULL;
|
fp_putc_t func = NULL;
|
||||||
switch(s_uart_debug_nr)
|
switch(s_uart_debug_nr)
|
||||||
{
|
{
|
||||||
case UART0:
|
case UART0:
|
||||||
@ -929,7 +929,7 @@ uart_set_debug(int uart_nr)
|
|||||||
} else {
|
} else {
|
||||||
system_set_os_print(0);
|
system_set_os_print(0);
|
||||||
}
|
}
|
||||||
ets_install_putc1((void *) func);
|
ets_install_putc1(func);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,25 +39,8 @@ bool ICACHE_FLASH_ATTR get_umm_get_perf_data(struct _UMM_TIME_STATS *p, size_t s
|
|||||||
Objective: To be able to print "last gasp" diagnostic messages
|
Objective: To be able to print "last gasp" diagnostic messages
|
||||||
when interrupts are disabled and w/o availability of heap resources.
|
when interrupts are disabled and w/o availability of heap resources.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// ROM _putc1, ignores CRs and sends CR/LF for LF, newline.
|
|
||||||
// Always returns character sent.
|
|
||||||
int constexpr (*_rom_putc1)(int) = (int (*)(int))0x40001dcc;
|
|
||||||
void uart_buff_switch(uint8_t);
|
|
||||||
|
|
||||||
int _isr_safe_printf_P(const char *fmt, ...) __attribute__((format(printf, 1, 2)));
|
int _isr_safe_printf_P(const char *fmt, ...) __attribute__((format(printf, 1, 2)));
|
||||||
int ICACHE_RAM_ATTR _isr_safe_printf_P(const char *fmt, ...) {
|
int ICACHE_RAM_ATTR _isr_safe_printf_P(const char *fmt, ...) {
|
||||||
#ifdef DEBUG_ESP_PORT
|
|
||||||
#define VALUE(x) __STRINGIFY(x)
|
|
||||||
// Preprocessor and compiler together will optimize away the if.
|
|
||||||
if (strcmp("Serial1", VALUE(DEBUG_ESP_PORT)) == 0) {
|
|
||||||
uart_buff_switch(1U);
|
|
||||||
} else {
|
|
||||||
uart_buff_switch(0U);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
uart_buff_switch(0U); // Side effect, clears RX FIFO
|
|
||||||
#endif
|
|
||||||
/*
|
/*
|
||||||
To use ets_strlen() and ets_memcpy() safely with PROGMEM, flash storage,
|
To use ets_strlen() and ets_memcpy() safely with PROGMEM, flash storage,
|
||||||
the PROGMEM address must be word (4 bytes) aligned. The destination
|
the PROGMEM address must be word (4 bytes) aligned. The destination
|
||||||
@ -71,7 +54,7 @@ int ICACHE_RAM_ATTR _isr_safe_printf_P(const char *fmt, ...) {
|
|||||||
ets_memcpy(ram_buf, fmt, buf_len);
|
ets_memcpy(ram_buf, fmt, buf_len);
|
||||||
va_list argPtr;
|
va_list argPtr;
|
||||||
va_start(argPtr, fmt);
|
va_start(argPtr, fmt);
|
||||||
int result = ets_vprintf(_rom_putc1, ram_buf, argPtr);
|
int result = ets_vprintf(ets_uart_putc1, ram_buf, argPtr);
|
||||||
va_end(argPtr);
|
va_end(argPtr);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,17 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This "print character function" prototype is modeled after the argument for
|
||||||
|
* ets_install_putc1() found in "ESP8266_NONOS_SDK/include/osapi.h". This
|
||||||
|
* deviates away from the familiar C library definition of putchar; however, it
|
||||||
|
* agrees with the code we are working with. Note, in the ROM some "printf
|
||||||
|
* character functions" always return 0 (uart_tx_one_char and ets_putc), some
|
||||||
|
* return last character printed (buildin _putc1), and some return nothing
|
||||||
|
* (ets_write_char). Using a void return type safely represents them all.
|
||||||
|
*/
|
||||||
|
typedef void (*fp_putc_t)(char);
|
||||||
|
|
||||||
typedef uint32_t ETSSignal;
|
typedef uint32_t ETSSignal;
|
||||||
typedef uint32_t ETSParam;
|
typedef uint32_t ETSParam;
|
||||||
|
|
||||||
@ -205,15 +216,41 @@ char *ets_strstr(const char *haystack, const char *needle);
|
|||||||
int ets_sprintf(char *str, const char *format, ...) __attribute__ ((format (printf, 2, 3)));
|
int ets_sprintf(char *str, const char *format, ...) __attribute__ ((format (printf, 2, 3)));
|
||||||
int os_snprintf(char *str, size_t size, const char *format, ...) __attribute__ ((format (printf, 3, 4)));
|
int os_snprintf(char *str, size_t size, const char *format, ...) __attribute__ ((format (printf, 3, 4)));
|
||||||
int ets_printf(const char *format, ...) __attribute__ ((format (printf, 1, 2)));
|
int ets_printf(const char *format, ...) __attribute__ ((format (printf, 1, 2)));
|
||||||
void ets_install_putc1(void* routine);
|
void ets_install_putc1(fp_putc_t routine);
|
||||||
void ets_isr_mask(int intr);
|
void ets_isr_mask(int intr);
|
||||||
void ets_isr_unmask(int intr);
|
void ets_isr_unmask(int intr);
|
||||||
void ets_isr_attach(int intr, int_handler_t handler, void *arg);
|
void ets_isr_attach(int intr, int_handler_t handler, void *arg);
|
||||||
void ets_intr_lock();
|
void ets_intr_lock();
|
||||||
void ets_intr_unlock();
|
void ets_intr_unlock();
|
||||||
int ets_vsnprintf(char * s, size_t n, const char * format, va_list arg) __attribute__ ((format (printf, 3, 0)));
|
int ets_vsnprintf(char * s, size_t n, const char * format, va_list arg) __attribute__ ((format (printf, 3, 0)));
|
||||||
int ets_vprintf(int (*print_function)(int), const char * format, va_list arg) __attribute__ ((format (printf, 2, 0)));
|
int ets_vprintf(fp_putc_t print_function, const char * format, va_list arg) __attribute__ ((format (printf, 2, 0)));
|
||||||
int ets_putc(int);
|
|
||||||
|
/*
|
||||||
|
* ets_putc(), a "print character function" in ROM, prints a character to a
|
||||||
|
* UART. It always returns 0; however, the prototype here is defined with void
|
||||||
|
* return to make compatible with other usages of fp_putc_t. ets_putc() provides
|
||||||
|
* a "raw", print as is, interface. '\r' and '\n' are each printed exactly as is
|
||||||
|
* w/o addition. For a "cooked" interface use ets_uart_putc1().
|
||||||
|
* The use of this function requires a prior setup call to uart_buff_switch() to
|
||||||
|
* select the UART.
|
||||||
|
*/
|
||||||
|
void ets_putc(char);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ets_uart_putc1(), a "print character function" in ROM, prints a character to
|
||||||
|
* a UART. It returns the character printed; however, the prototype here is
|
||||||
|
* defined with void return to make compatible with other usages of fp_putc_t.
|
||||||
|
* This function provides additional processing to characters '\r' and '\n'. It
|
||||||
|
* filters out '\r'. When called with '\n', it prints characters '\r' and '\n'.
|
||||||
|
* This is sometimes refered to as a "cooked" interface. For a "raw", print as
|
||||||
|
* is, interface use ets_putc(). The use of this function requires a prior setup
|
||||||
|
* call to uart_buff_switch() to select the UART.
|
||||||
|
* ets_uart_putc1() is used internally by ets_uart_printf. It is also the
|
||||||
|
* function that gets installed by ets_uart_install_printf through a call to
|
||||||
|
* ets_install_putc1.
|
||||||
|
*/
|
||||||
|
void ets_uart_putc1(char);
|
||||||
|
|
||||||
bool ets_task(ETSTask task, uint8 prio, ETSEvent *queue, uint8 qlen);
|
bool ets_task(ETSTask task, uint8 prio, ETSEvent *queue, uint8 qlen);
|
||||||
bool ets_post(uint8 prio, ETSSignal sig, ETSParam par);
|
bool ets_post(uint8 prio, ETSSignal sig, ETSParam par);
|
||||||
void ets_update_cpu_frequency(uint32_t ticks_per_us);
|
void ets_update_cpu_frequency(uint32_t ticks_per_us);
|
||||||
|
@ -119,6 +119,8 @@ PROVIDE ( ets_install_external_printf = 0x40002450 );
|
|||||||
PROVIDE ( ets_install_putc1 = 0x4000242c );
|
PROVIDE ( ets_install_putc1 = 0x4000242c );
|
||||||
PROVIDE ( ets_install_putc2 = 0x4000248c );
|
PROVIDE ( ets_install_putc2 = 0x4000248c );
|
||||||
PROVIDE ( ets_install_uart_printf = 0x40002438 );
|
PROVIDE ( ets_install_uart_printf = 0x40002438 );
|
||||||
|
/* Undocumented function to print character to UART */
|
||||||
|
PROVIDE ( ets_uart_putc1 = 0x40001dcc );
|
||||||
/* permanently hide reimplemented ets_intr_*lock(), see #6484
|
/* permanently hide reimplemented ets_intr_*lock(), see #6484
|
||||||
PROVIDE ( ets_intr_lock = 0x40000f74 );
|
PROVIDE ( ets_intr_lock = 0x40000f74 );
|
||||||
PROVIDE ( ets_intr_unlock = 0x40000f80 );
|
PROVIDE ( ets_intr_unlock = 0x40000f80 );
|
||||||
|
Loading…
x
Reference in New Issue
Block a user