8c99c27df1
Looks like the option is generally not compatible with garbage collections. Nothing gets inlined, for example is_smp_boot() no longer evaluates to constant false and thus the symbols from secondary.S would need to be present for the build to pass even if we set SMP=n. Also the addresses of relocatable ramstage are currently not normalised on the logs, so util/genprof would be unable dress those. Change-Id: I0b6f310e15e6f4992cd054d288903fea8390e5cf Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/45757 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Angel Pons <th3fanbus@gmail.com> Reviewed-by: Nico Huber <nico.h@gmx.de>
45 lines
789 B
C
45 lines
789 B
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
|
|
#include <console/vtxprintf.h>
|
|
#include <string.h>
|
|
|
|
struct vsnprintf_context {
|
|
char *str_buf;
|
|
size_t buf_limit;
|
|
};
|
|
|
|
static void str_tx_byte(unsigned char byte, void *data)
|
|
{
|
|
struct vsnprintf_context *ctx = data;
|
|
if (ctx->buf_limit) {
|
|
*ctx->str_buf = byte;
|
|
ctx->str_buf++;
|
|
ctx->buf_limit--;
|
|
}
|
|
}
|
|
|
|
int vsnprintf(char *buf, size_t size, const char *fmt, va_list args)
|
|
{
|
|
int i;
|
|
struct vsnprintf_context ctx;
|
|
|
|
ctx.str_buf = buf;
|
|
ctx.buf_limit = size ? size - 1 : 0;
|
|
i = vtxprintf(str_tx_byte, fmt, args, &ctx);
|
|
if (size)
|
|
*ctx.str_buf = '\0';
|
|
|
|
return i;
|
|
}
|
|
|
|
int snprintf(char *buf, size_t size, const char *fmt, ...)
|
|
{
|
|
va_list args;
|
|
int i;
|
|
|
|
va_start(args, fmt);
|
|
i = vsnprintf(buf, size, fmt, args);
|
|
va_end(args);
|
|
|
|
return i;
|
|
}
|