Remix.run Logo
PhilipRoman 5 days ago

Log to a memory ring buffer (if you need extreme precision, prefetch everything and write binary fixed size "log entries"), flush asynchronously at some point when you don't care about timing anymore. Really helpful in kernel debugging.

mrheosuper 5 days ago | parent [-]

Formatting log still takes considerable computing, especially when working on embedded system, where your cpu is only a few hundreds MHz.

rcxdude 4 days ago | parent | next [-]

You don't need to format the log on-device. You can push a binary representation and format when you need to display it. Look a 'defmt' for an example of this approach. Logging overhead in the path that emits the log messages can be tens of instructions.

sandos 5 days ago | parent | prev [-]

Hence the mention of binary stuff.... We use ftrace in linux and we limit ourselves a lot on what we "print".