diff options
| author | skullY <skullydazed@gmail.com> | 2020-05-04 09:25:44 -0700 |
|---|---|---|
| committer | skullY <skullydazed@gmail.com> | 2020-05-04 09:25:44 -0700 |
| commit | 6f30b402a285ddecce9b6f5b002a649f775225d2 (patch) | |
| tree | 5a25c7334d931a56d9fbfad80b6284cda7e38950 | |
| parent | 1ff526dac0e73ea8cce522d0106631e3a748802c (diff) | |
| download | qmk_firmware-6f30b402a285ddecce9b6f5b002a649f775225d2.tar.gz qmk_firmware-6f30b402a285ddecce9b6f5b002a649f775225d2.zip | |
Revert "Fix conflicting types for 'tfp_printf' (#8269)"
This reverts commit e17b55e33ad5b3dcefcf7b828ac99aeb2daeeae2.
| -rw-r--r-- | .gitmodules | 3 | ||||
| -rw-r--r-- | Makefile | 1 | ||||
| m--------- | lib/printf | 0 | ||||
| -rw-r--r-- | tmk_core/common.mk | 9 | ||||
| -rw-r--r-- | tmk_core/common/chibios/printf.c | 233 | ||||
| -rw-r--r-- | tmk_core/common/chibios/printf.h | 110 | ||||
| -rw-r--r-- | tmk_core/common/print.h | 5 | ||||
| -rw-r--r-- | tmk_core/protocol/chibios/main.c | 3 | ||||
| -rw-r--r-- | tmk_core/protocol/chibios/usb_main.c | 5 | ||||
| -rw-r--r-- | tmk_core/protocol/chibios/usb_main.h | 2 |
10 files changed, 357 insertions, 14 deletions
diff --git a/.gitmodules b/.gitmodules index b8c66034b..6d8ab8b94 100644 --- a/.gitmodules +++ b/.gitmodules | |||
| @@ -16,6 +16,3 @@ | |||
| 16 | [submodule "lib/lufa"] | 16 | [submodule "lib/lufa"] |
| 17 | path = lib/lufa | 17 | path = lib/lufa |
| 18 | url = https://github.com/qmk/lufa | 18 | url = https://github.com/qmk/lufa |
| 19 | [submodule "lib/printf"] | ||
| 20 | path = lib/printf | ||
| 21 | url = https://github.com/mpaland/printf.git | ||
| @@ -567,7 +567,6 @@ ifndef SKIP_GIT | |||
| 567 | if [ ! -e lib/chibios-contrib ]; then git submodule sync lib/chibios-contrib && git submodule update --depth 50 --init lib/chibios-contrib; fi | 567 | if [ ! -e lib/chibios-contrib ]; then git submodule sync lib/chibios-contrib && git submodule update --depth 50 --init lib/chibios-contrib; fi |
| 568 | if [ ! -e lib/ugfx ]; then git submodule sync lib/ugfx && git submodule update --depth 50 --init lib/ugfx; fi | 568 | if [ ! -e lib/ugfx ]; then git submodule sync lib/ugfx && git submodule update --depth 50 --init lib/ugfx; fi |
| 569 | if [ ! -e lib/lufa ]; then git submodule sync lib/lufa && git submodule update --depth 50 --init lib/lufa; fi | 569 | if [ ! -e lib/lufa ]; then git submodule sync lib/lufa && git submodule update --depth 50 --init lib/lufa; fi |
| 570 | if [ ! -e lib/printf ]; then git submodule sync lib/printf && git submodule update --depth 50 --init lib/printf; fi | ||
| 571 | git submodule status --recursive 2>/dev/null | \ | 570 | git submodule status --recursive 2>/dev/null | \ |
| 572 | while IFS= read -r x; do \ | 571 | while IFS= read -r x; do \ |
| 573 | case "$$x" in \ | 572 | case "$$x" in \ |
diff --git a/lib/printf b/lib/printf deleted file mode 160000 | |||
| Subproject d3b984684bb8a8bdc48cc7a1abecb93ce59bbe3 | |||
diff --git a/tmk_core/common.mk b/tmk_core/common.mk index 63de7c7ed..aa8a0eb7a 100644 --- a/tmk_core/common.mk +++ b/tmk_core/common.mk | |||
| @@ -1,5 +1,3 @@ | |||
| 1 | PRINTF_PATH = $(LIB_PATH)/printf | ||
| 2 | |||
| 3 | COMMON_DIR = common | 1 | COMMON_DIR = common |
| 4 | PLATFORM_COMMON_DIR = $(COMMON_DIR)/$(PLATFORM_KEY) | 2 | PLATFORM_COMMON_DIR = $(COMMON_DIR)/$(PLATFORM_KEY) |
| 5 | 3 | ||
| @@ -23,12 +21,7 @@ TMK_COMMON_SRC += $(COMMON_DIR)/host.c \ | |||
| 23 | ifeq ($(PLATFORM),AVR) | 21 | ifeq ($(PLATFORM),AVR) |
| 24 | TMK_COMMON_SRC += $(PLATFORM_COMMON_DIR)/xprintf.S | 22 | TMK_COMMON_SRC += $(PLATFORM_COMMON_DIR)/xprintf.S |
| 25 | else ifeq ($(PLATFORM),CHIBIOS) | 23 | else ifeq ($(PLATFORM),CHIBIOS) |
| 26 | TMK_COMMON_SRC += $(PRINTF_PATH)/printf.c | 24 | TMK_COMMON_SRC += $(PLATFORM_COMMON_DIR)/printf.c |
| 27 | TMK_COMMON_DEFS += -DPRINTF_DISABLE_SUPPORT_FLOAT | ||
| 28 | TMK_COMMON_DEFS += -DPRINTF_DISABLE_SUPPORT_EXPONENTIAL | ||
| 29 | TMK_COMMON_DEFS += -DPRINTF_DISABLE_SUPPORT_LONG_LONG | ||
| 30 | TMK_COMMON_DEFS += -DPRINTF_DISABLE_SUPPORT_PTRDIFF_T | ||
| 31 | VPATH += $(PRINTF_PATH) | ||
| 32 | else ifeq ($(PLATFORM),ARM_ATSAM) | 25 | else ifeq ($(PLATFORM),ARM_ATSAM) |
| 33 | TMK_COMMON_SRC += $(PLATFORM_COMMON_DIR)/printf.c | 26 | TMK_COMMON_SRC += $(PLATFORM_COMMON_DIR)/printf.c |
| 34 | endif | 27 | endif |
diff --git a/tmk_core/common/chibios/printf.c b/tmk_core/common/chibios/printf.c new file mode 100644 index 000000000..a99752bb3 --- /dev/null +++ b/tmk_core/common/chibios/printf.c | |||
| @@ -0,0 +1,233 @@ | |||
| 1 | /* | ||
| 2 | * found at: http://www.sparetimelabs.com/tinyprintf/tinyprintf.php | ||
| 3 | * and: http://www.sparetimelabs.com/printfrevisited/printfrevisited.php | ||
| 4 | */ | ||
| 5 | |||
| 6 | /* | ||
| 7 | File: printf.c | ||
| 8 | |||
| 9 | Copyright (C) 2004 Kustaa Nyholm | ||
| 10 | |||
| 11 | This library is free software; you can redistribute it and/or | ||
| 12 | modify it under the terms of the GNU Lesser General Public | ||
| 13 | License as published by the Free Software Foundation; either | ||
| 14 | version 2.1 of the License, or (at your option) any later version. | ||
| 15 | |||
| 16 | This library is distributed in the hope that it will be useful, | ||
| 17 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 18 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| 19 | Lesser General Public License for more details. | ||
| 20 | |||
| 21 | You should have received a copy of the GNU Lesser General Public | ||
| 22 | License along with this library; if not, write to the Free Software | ||
| 23 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 24 | |||
| 25 | */ | ||
| 26 | |||
| 27 | #include "printf.h" | ||
| 28 | |||
| 29 | typedef void (*putcf)(void*, char); | ||
| 30 | static putcf stdout_putf; | ||
| 31 | static void* stdout_putp; | ||
| 32 | |||
| 33 | // this adds cca 400 bytes | ||
| 34 | #define PRINTF_LONG_SUPPORT | ||
| 35 | |||
| 36 | #ifdef PRINTF_LONG_SUPPORT | ||
| 37 | |||
| 38 | static void uli2a(unsigned long int num, unsigned int base, int uc, char* bf) { | ||
| 39 | int n = 0; | ||
| 40 | unsigned int d = 1; | ||
| 41 | while (num / d >= base) d *= base; | ||
| 42 | while (d != 0) { | ||
| 43 | int dgt = num / d; | ||
| 44 | num %= d; | ||
| 45 | d /= base; | ||
| 46 | if (n || dgt > 0 || d == 0) { | ||
| 47 | *bf++ = dgt + (dgt < 10 ? '0' : (uc ? 'A' : 'a') - 10); | ||
| 48 | ++n; | ||
| 49 | } | ||
| 50 | } | ||
| 51 | *bf = 0; | ||
| 52 | } | ||
| 53 | |||
| 54 | static void li2a(long num, char* bf) { | ||
| 55 | if (num < 0) { | ||
| 56 | num = -num; | ||
| 57 | *bf++ = '-'; | ||
| 58 | } | ||
| 59 | uli2a(num, 10, 0, bf); | ||
| 60 | } | ||
| 61 | |||
| 62 | #endif | ||
| 63 | |||
| 64 | static void ui2a(unsigned int num, unsigned int base, int uc, char* bf) { | ||
| 65 | int n = 0; | ||
| 66 | unsigned int d = 1; | ||
| 67 | while (num / d >= base) d *= base; | ||
| 68 | while (d != 0) { | ||
| 69 | int dgt = num / d; | ||
| 70 | num %= d; | ||
| 71 | d /= base; | ||
| 72 | if (n || dgt > 0 || d == 0) { | ||
| 73 | *bf++ = dgt + (dgt < 10 ? '0' : (uc ? 'A' : 'a') - 10); | ||
| 74 | ++n; | ||
| 75 | } | ||
| 76 | } | ||
| 77 | *bf = 0; | ||
| 78 | } | ||
| 79 | |||
| 80 | static void i2a(int num, char* bf) { | ||
| 81 | if (num < 0) { | ||
| 82 | num = -num; | ||
| 83 | *bf++ = '-'; | ||
| 84 | } | ||
| 85 | ui2a(num, 10, 0, bf); | ||
| 86 | } | ||
| 87 | |||
| 88 | static int a2d(char ch) { | ||
| 89 | if (ch >= '0' && ch <= '9') | ||
| 90 | return ch - '0'; | ||
| 91 | else if (ch >= 'a' && ch <= 'f') | ||
| 92 | return ch - 'a' + 10; | ||
| 93 | else if (ch >= 'A' && ch <= 'F') | ||
| 94 | return ch - 'A' + 10; | ||
| 95 | else | ||
| 96 | return -1; | ||
| 97 | } | ||
| 98 | |||
| 99 | static char a2i(char ch, const char** src, int base, int* nump) { | ||
| 100 | const char* p = *src; | ||
| 101 | int num = 0; | ||
| 102 | int digit; | ||
| 103 | while ((digit = a2d(ch)) >= 0) { | ||
| 104 | if (digit > base) break; | ||
| 105 | num = num * base + digit; | ||
| 106 | ch = *p++; | ||
| 107 | } | ||
| 108 | *src = p; | ||
| 109 | *nump = num; | ||
| 110 | return ch; | ||
| 111 | } | ||
| 112 | |||
| 113 | static void putchw(void* putp, putcf putf, int n, char z, char* bf) { | ||
| 114 | char fc = z ? '0' : ' '; | ||
| 115 | char ch; | ||
| 116 | char* p = bf; | ||
| 117 | while (*p++ && n > 0) n--; | ||
| 118 | while (n-- > 0) putf(putp, fc); | ||
| 119 | while ((ch = *bf++)) putf(putp, ch); | ||
| 120 | } | ||
| 121 | |||
| 122 | void tfp_format(void* putp, putcf putf, const char* fmt, va_list va) { | ||
| 123 | // This used to handle max of 12, but binary support jumps this to at least 32 | ||
| 124 | char bf[36]; | ||
| 125 | |||
| 126 | char ch; | ||
| 127 | |||
| 128 | while ((ch = *(fmt++))) { | ||
| 129 | if (ch != '%') | ||
| 130 | putf(putp, ch); | ||
| 131 | else { | ||
| 132 | char lz = 0; | ||
| 133 | #ifdef PRINTF_LONG_SUPPORT | ||
| 134 | char lng = 0; | ||
| 135 | #endif | ||
| 136 | int w = 0; | ||
| 137 | ch = *(fmt++); | ||
| 138 | if (ch == '0') { | ||
| 139 | ch = *(fmt++); | ||
| 140 | lz = 1; | ||
| 141 | } | ||
| 142 | if (ch >= '0' && ch <= '9') { | ||
| 143 | ch = a2i(ch, &fmt, 10, &w); | ||
| 144 | } | ||
| 145 | #ifdef PRINTF_LONG_SUPPORT | ||
| 146 | if (ch == 'l') { | ||
| 147 | ch = *(fmt++); | ||
| 148 | lng = 1; | ||
| 149 | } | ||
| 150 | #endif | ||
| 151 | switch (ch) { | ||
| 152 | case 0: | ||
| 153 | goto abort; | ||
| 154 | case 'u': { | ||
| 155 | #ifdef PRINTF_LONG_SUPPORT | ||
| 156 | if (lng) | ||
| 157 | uli2a(va_arg(va, unsigned long int), 10, 0, bf); | ||
| 158 | else | ||
| 159 | #endif | ||
| 160 | ui2a(va_arg(va, unsigned int), 10, 0, bf); | ||
| 161 | putchw(putp, putf, w, lz, bf); | ||
| 162 | break; | ||
| 163 | } | ||
| 164 | case 'd': { | ||
| 165 | #ifdef PRINTF_LONG_SUPPORT | ||
| 166 | if (lng) | ||
| 167 | li2a(va_arg(va, unsigned long int), bf); | ||
| 168 | else | ||
| 169 | #endif | ||
| 170 | i2a(va_arg(va, int), bf); | ||
| 171 | putchw(putp, putf, w, lz, bf); | ||
| 172 | break; | ||
| 173 | } | ||
| 174 | case 'x': | ||
| 175 | case 'X': | ||
| 176 | #ifdef PRINTF_LONG_SUPPORT | ||
| 177 | if (lng) | ||
| 178 | uli2a(va_arg(va, unsigned long int), 16, (ch == 'X'), bf); | ||
| 179 | else | ||
| 180 | #endif | ||
| 181 | ui2a(va_arg(va, unsigned int), 16, (ch == 'X'), bf); | ||
| 182 | putchw(putp, putf, w, lz, bf); | ||
| 183 | break; | ||
| 184 | case 'c': | ||
| 185 | putf(putp, (char)(va_arg(va, int))); | ||
| 186 | break; | ||
| 187 | case 's': | ||
| 188 | putchw(putp, putf, w, 0, va_arg(va, char*)); | ||
| 189 | break; | ||
| 190 | case 'b': | ||
| 191 | #ifdef PRINTF_LONG_SUPPORT | ||
| 192 | if (lng) | ||
| 193 | uli2a(va_arg(va, unsigned long int), 2, 0, bf); | ||
| 194 | else | ||
| 195 | #endif | ||
| 196 | ui2a(va_arg(va, unsigned int), 2, 0, bf); | ||
| 197 | putchw(putp, putf, w, lz, bf); | ||
| 198 | break; | ||
| 199 | case '%': | ||
| 200 | putf(putp, ch); | ||
| 201 | default: | ||
| 202 | break; | ||
| 203 | } | ||
| 204 | } | ||
| 205 | } | ||
| 206 | abort:; | ||
| 207 | } | ||
| 208 | |||
| 209 | void init_printf(void* putp, void (*putf)(void*, char)) { | ||
| 210 | stdout_putf = putf; | ||
| 211 | stdout_putp = putp; | ||
| 212 | } | ||
| 213 | |||
| 214 | int tfp_printf(const char* fmt, ...) { | ||
| 215 | va_list va; | ||
| 216 | va_start(va, fmt); | ||
| 217 | tfp_format(stdout_putp, stdout_putf, fmt, va); | ||
| 218 | va_end(va); | ||
| 219 | |||
| 220 | return 1; | ||
| 221 | } | ||
| 222 | |||
| 223 | static void putcp(void* p, char c) { *(*((char**)p))++ = c; } | ||
| 224 | |||
| 225 | int tfp_sprintf(char* s, const char* fmt, ...) { | ||
| 226 | va_list va; | ||
| 227 | va_start(va, fmt); | ||
| 228 | tfp_format(&s, putcp, fmt, va); | ||
| 229 | putcp(&s, 0); | ||
| 230 | va_end(va); | ||
| 231 | |||
| 232 | return 1; | ||
| 233 | } | ||
diff --git a/tmk_core/common/chibios/printf.h b/tmk_core/common/chibios/printf.h new file mode 100644 index 000000000..775459e1e --- /dev/null +++ b/tmk_core/common/chibios/printf.h | |||
| @@ -0,0 +1,110 @@ | |||
| 1 | /* | ||
| 2 | * found at: http://www.sparetimelabs.com/tinyprintf/tinyprintf.php | ||
| 3 | * and: http://www.sparetimelabs.com/printfrevisited/printfrevisited.php | ||
| 4 | */ | ||
| 5 | |||
| 6 | /* | ||
| 7 | File: printf.h | ||
| 8 | |||
| 9 | Copyright (C) 2004 Kustaa Nyholm | ||
| 10 | |||
| 11 | This library is free software; you can redistribute it and/or | ||
| 12 | modify it under the terms of the GNU Lesser General Public | ||
| 13 | License as published by the Free Software Foundation; either | ||
| 14 | version 2.1 of the License, or (at your option) any later version. | ||
| 15 | |||
| 16 | This library is distributed in the hope that it will be useful, | ||
| 17 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 18 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | ||
| 19 | See the GNU Lesser General Public License for more details. | ||
| 20 | |||
| 21 | You should have received a copy of the GNU Lesser General Public | ||
| 22 | License along with this library; if not, write to the Free Software | ||
| 23 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 24 | |||
| 25 | This library is realy just two files: 'printf.h' and 'printf.c'. | ||
| 26 | |||
| 27 | They provide a simple and small (+200 loc) printf functionality to | ||
| 28 | be used in embedded systems. | ||
| 29 | |||
| 30 | I've found them so usefull in debugging that I do not bother with a | ||
| 31 | debugger at all. | ||
| 32 | |||
| 33 | They are distributed in source form, so to use them, just compile them | ||
| 34 | into your project. | ||
| 35 | |||
| 36 | Two printf variants are provided: printf and sprintf. | ||
| 37 | |||
| 38 | The formats supported by this implementation are: 'd' 'u' 'c' 's' 'x' 'X'. | ||
| 39 | |||
| 40 | Zero padding and field width are also supported. | ||
| 41 | |||
| 42 | If the library is compiled with 'PRINTF_SUPPORT_LONG' defined then the | ||
| 43 | long specifier is also | ||
| 44 | supported. Note that this will pull in some long math routines (pun intended!) | ||
| 45 | and thus make your executable noticably longer. | ||
| 46 | |||
| 47 | The memory foot print of course depends on the target cpu, compiler and | ||
| 48 | compiler options, but a rough guestimate (based on a H8S target) is about | ||
| 49 | 1.4 kB for code and some twenty 'int's and 'char's, say 60 bytes of stack space. | ||
| 50 | Not too bad. Your milage may vary. By hacking the source code you can | ||
| 51 | get rid of some hunred bytes, I'm sure, but personally I feel the balance of | ||
| 52 | functionality and flexibility versus code size is close to optimal for | ||
| 53 | many embedded systems. | ||
| 54 | |||
| 55 | To use the printf you need to supply your own character output function, | ||
| 56 | something like : | ||
| 57 | |||
| 58 | void putc ( void* p, char c) | ||
| 59 | { | ||
| 60 | while (!SERIAL_PORT_EMPTY) ; | ||
| 61 | SERIAL_PORT_TX_REGISTER = c; | ||
| 62 | } | ||
| 63 | |||
| 64 | Before you can call printf you need to initialize it to use your | ||
| 65 | character output function with something like: | ||
| 66 | |||
| 67 | init_printf(NULL,putc); | ||
| 68 | |||
| 69 | Notice the 'NULL' in 'init_printf' and the parameter 'void* p' in 'putc', | ||
| 70 | the NULL (or any pointer) you pass into the 'init_printf' will eventually be | ||
| 71 | passed to your 'putc' routine. This allows you to pass some storage space (or | ||
| 72 | anything realy) to the character output function, if necessary. | ||
| 73 | This is not often needed but it was implemented like that because it made | ||
| 74 | implementing the sprintf function so neat (look at the source code). | ||
| 75 | |||
| 76 | The code is re-entrant, except for the 'init_printf' function, so it | ||
| 77 | is safe to call it from interupts too, although this may result in mixed output. | ||
| 78 | If you rely on re-entrancy, take care that your 'putc' function is re-entrant! | ||
| 79 | |||
| 80 | The printf and sprintf functions are actually macros that translate to | ||
| 81 | 'tfp_printf' and 'tfp_sprintf'. This makes it possible | ||
| 82 | to use them along with 'stdio.h' printf's in a single source file. | ||
| 83 | You just need to undef the names before you include the 'stdio.h'. | ||
| 84 | Note that these are not function like macros, so if you have variables | ||
| 85 | or struct members with these names, things will explode in your face. | ||
| 86 | Without variadic macros this is the best we can do to wrap these | ||
| 87 | fucnction. If it is a problem just give up the macros and use the | ||
| 88 | functions directly or rename them. | ||
| 89 | |||
| 90 | For further details see source code. | ||
| 91 | |||
| 92 | regs Kusti, 23.10.2004 | ||
| 93 | */ | ||
| 94 | |||
| 95 | #ifndef __TFP_PRINTF__ | ||
| 96 | #define __TFP_PRINTF__ | ||
| 97 | |||
| 98 | #include <stdarg.h> | ||
| 99 | |||
| 100 | void init_printf(void* putp, void (*putf)(void*, char)); | ||
| 101 | |||
| 102 | int tfp_printf(const char* fmt, ...); | ||
| 103 | int tfp_sprintf(char* s, const char* fmt, ...); | ||
| 104 | |||
| 105 | void tfp_format(void* putp, void (*putf)(void*, char), const char* fmt, va_list va); | ||
| 106 | |||
| 107 | #define printf tfp_printf | ||
| 108 | #define sprintf tfp_sprintf | ||
| 109 | |||
| 110 | #endif | ||
diff --git a/tmk_core/common/print.h b/tmk_core/common/print.h index 1c7723621..04ca55810 100644 --- a/tmk_core/common/print.h +++ b/tmk_core/common/print.h | |||
| @@ -72,7 +72,9 @@ extern "C" | |||
| 72 | 72 | ||
| 73 | # elif defined(PROTOCOL_CHIBIOS) /* PROTOCOL_CHIBIOS */ | 73 | # elif defined(PROTOCOL_CHIBIOS) /* PROTOCOL_CHIBIOS */ |
| 74 | 74 | ||
| 75 | # include "printf.h" // lib/printf/printf.h | 75 | # ifndef TERMINAL_ENABLE |
| 76 | # include "chibios/printf.h" | ||
| 77 | # endif | ||
| 76 | 78 | ||
| 77 | # ifdef USER_PRINT /* USER_PRINT */ | 79 | # ifdef USER_PRINT /* USER_PRINT */ |
| 78 | 80 | ||
| @@ -87,6 +89,7 @@ extern "C" | |||
| 87 | # define uprintf printf | 89 | # define uprintf printf |
| 88 | 90 | ||
| 89 | # else /* NORMAL PRINT */ | 91 | # else /* NORMAL PRINT */ |
| 92 | |||
| 90 | // Create user & normal print defines | 93 | // Create user & normal print defines |
| 91 | # define print(s) printf(s) | 94 | # define print(s) printf(s) |
| 92 | # define println(s) printf(s "\r\n") | 95 | # define println(s) printf(s "\r\n") |
diff --git a/tmk_core/protocol/chibios/main.c b/tmk_core/protocol/chibios/main.c index 7d32c16ed..61665eb6f 100644 --- a/tmk_core/protocol/chibios/main.c +++ b/tmk_core/protocol/chibios/main.c | |||
| @@ -158,6 +158,9 @@ int main(void) { | |||
| 158 | /* Init USB */ | 158 | /* Init USB */ |
| 159 | init_usb_driver(&USB_DRIVER); | 159 | init_usb_driver(&USB_DRIVER); |
| 160 | 160 | ||
| 161 | /* init printf */ | ||
| 162 | init_printf(NULL, sendchar_pf); | ||
| 163 | |||
| 161 | #ifdef MIDI_ENABLE | 164 | #ifdef MIDI_ENABLE |
| 162 | setup_midi(); | 165 | setup_midi(); |
| 163 | #endif | 166 | #endif |
diff --git a/tmk_core/protocol/chibios/usb_main.c b/tmk_core/protocol/chibios/usb_main.c index 66985b9de..ecc83d9ec 100644 --- a/tmk_core/protocol/chibios/usb_main.c +++ b/tmk_core/protocol/chibios/usb_main.c | |||
| @@ -796,7 +796,10 @@ int8_t sendchar(uint8_t c) { | |||
| 796 | } | 796 | } |
| 797 | #endif /* CONSOLE_ENABLE */ | 797 | #endif /* CONSOLE_ENABLE */ |
| 798 | 798 | ||
| 799 | void _putchar(char character) { sendchar(character); } | 799 | void sendchar_pf(void *p, char c) { |
| 800 | (void)p; | ||
| 801 | sendchar((uint8_t)c); | ||
| 802 | } | ||
| 800 | 803 | ||
| 801 | #ifdef RAW_ENABLE | 804 | #ifdef RAW_ENABLE |
| 802 | void raw_hid_send(uint8_t *data, uint8_t length) { | 805 | void raw_hid_send(uint8_t *data, uint8_t length) { |
diff --git a/tmk_core/protocol/chibios/usb_main.h b/tmk_core/protocol/chibios/usb_main.h index 94baf9b35..17041b4f2 100644 --- a/tmk_core/protocol/chibios/usb_main.h +++ b/tmk_core/protocol/chibios/usb_main.h | |||
| @@ -87,4 +87,6 @@ void console_flush_output(void); | |||
| 87 | 87 | ||
| 88 | #endif /* CONSOLE_ENABLE */ | 88 | #endif /* CONSOLE_ENABLE */ |
| 89 | 89 | ||
| 90 | void sendchar_pf(void *p, char c); | ||
| 91 | |||
| 90 | #endif /* _USB_MAIN_H_ */ | 92 | #endif /* _USB_MAIN_H_ */ |
