Zephyr Project API  3.3.0
A Scalable Open Source RTOS
cbprintf.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2020 Nordic Semiconductor ASA
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#ifndef ZEPHYR_INCLUDE_SYS_CBPRINTF_H_
8#define ZEPHYR_INCLUDE_SYS_CBPRINTF_H_
9
10#include <stdarg.h>
11#include <stddef.h>
12#include <stdint.h>
13#include <zephyr/toolchain.h>
14#include <string.h>
15
16#ifdef CONFIG_CBPRINTF_LIBC_SUBSTS
17#include <stdio.h>
18#endif /* CONFIG_CBPRINTF_LIBC_SUBSTS */
19
20/* Determine if _Generic is supported using macro from toolchain.h.
21 *
22 * @note Z_C_GENERIC is also set for C++ where functionality is implemented
23 * using overloading and templates.
24 */
25#ifndef Z_C_GENERIC
26#if defined(__cplusplus) || TOOLCHAIN_HAS_C_GENERIC
27#define Z_C_GENERIC 1
28#else
29#define Z_C_GENERIC 0
30#endif
31#endif
32
33#ifdef __xtensa__
34#define Z_PKG_HDR_EXT_XTENSA_ALIGNMENT 8
35#ifdef CONFIG_CBPRINTF_PACKAGE_HEADER_STORE_CREATION_FLAGS
36#define Z_PKG_DESC_XTENSA_PADDING 1
37#else
38#define Z_PKG_DESC_XTENSA_PADDING 0
39#endif
40#endif /* __xtensa__ */
41
48
51
54
57
58#ifdef CONFIG_CBPRINTF_PACKAGE_HEADER_STORE_CREATION_FLAGS
60 uint32_t pkg_flags;
61#endif
62#ifdef __xtensa__
63 /*
64 * On Xtensa, the first argument needs to be aligned to 8-byte.
65 * With 32-bit pointers, we need another 4 bytes padding so
66 * that whole struct cbprintf_package_hdr_ext is of multiple of
67 * 8 bytes.
68 */
69 uint32_t xtensa_padding[Z_PKG_DESC_XTENSA_PADDING];
70#endif
71
72} __packed;
73
81
82 void *raw;
83
84#if defined(CONFIG_CBPRINTF_PACKAGE_HEADER_STORE_CREATION_FLAGS) && !defined(CONFIG_64BIT)
85 void *raw2[2];
86#endif
87
88} __packed;
89
90
91
99
101 char *fmt;
102
103 /*
104 * When extending this struct, make sure this align
105 * to pointer size.
106 */
107} __packed;
108
109
115#ifdef __xtensa__
116BUILD_ASSERT(sizeof(struct cbprintf_package_hdr_ext) % Z_PKG_HDR_EXT_XTENSA_ALIGNMENT == 0,
117 "Package header size on Xtensa must be aligned");
118#endif
123/* Z_C_GENERIC is used there */
125
126#ifdef __cplusplus
127extern "C" {
128#endif
129
137#ifdef __xtensa__
138#define CBPRINTF_PACKAGE_ALIGNMENT 16
139#else
140#define CBPRINTF_PACKAGE_ALIGNMENT \
141 Z_POW2_CEIL(COND_CODE_1(CONFIG_CBPRINTF_PACKAGE_LONGDOUBLE, \
142 (sizeof(long double)), (MAX(sizeof(double), sizeof(long long)))))
143#endif
144
145BUILD_ASSERT(Z_IS_POW2(CBPRINTF_PACKAGE_ALIGNMENT));
146
147
156#define CBPRINTF_PACKAGE_CONST_CHAR_RO BIT(0)
157
159#define CBPRINTF_PACKAGE_ADD_RO_STR_POS BIT(1)
160
165#define CBPRINTF_PACKAGE_ADD_RW_STR_POS BIT(2)
166
167#define Z_CBPRINTF_PACKAGE_FIRST_RO_STR_BITS 3
168#define Z_CBPRINTF_PACKAGE_FIRST_RO_STR_OFFSET 3
169#define Z_CBPRINTF_PACKAGE_FIRST_RO_STR_MASK BIT_MASK(Z_CBPRINTF_PACKAGE_FIRST_RO_STR_BITS)
170
178#define CBPRINTF_PACKAGE_FIRST_RO_STR_CNT(n) \
179 (n << Z_CBPRINTF_PACKAGE_FIRST_RO_STR_OFFSET)
180
184#define Z_CBPRINTF_PACKAGE_FIRST_RO_STR_CNT_GET(flags) \
185 (((flags) >> Z_CBPRINTF_PACKAGE_FIRST_RO_STR_OFFSET) & Z_CBPRINTF_PACKAGE_FIRST_RO_STR_MASK)
186
193#define CBPRINTF_PACKAGE_ADD_STRING_IDXS \
194 (CBPRINTF_PACKAGE_ADD_RO_STR_POS | CBPRINTF_PACKAGE_CONST_CHAR_RO)
195
201#define CBPRINTF_PACKAGE_ARGS_ARE_TAGGED BIT(6)
202
217#define CBPRINTF_PACKAGE_CONVERT_RO_STR BIT(0)
218#define CBPRINTF_PACKAGE_COPY_RO_STR CBPRINTF_PACKAGE_CONVERT_RO_STR __DEPRECATED_MACRO
219
230#define CBPRINTF_PACKAGE_CONVERT_RW_STR BIT(1)
231#define CBPRINTF_PACKAGE_COPY_RW_STR CBPRINTF_PACKAGE_CONVERT_RW_STR __DEPRECATED_MACRO
232
238#define CBPRINTF_PACKAGE_CONVERT_KEEP_RO_STR BIT(2)
239#define CBPRINTF_PACKAGE_COPY_KEEP_RO_STR CBPRINTF_PACKAGE_CONVERT_KEEP_RO_STR __DEPRECATED_MACRO
240
258#define CBPRINTF_PACKAGE_CONVERT_PTR_CHECK BIT(3)
259
271#define Z_CBVPRINTF_PROCESS_FLAG_TAGGED_ARGS BIT(0)
272
276
294#ifdef __CHECKER__
295typedef int (*cbprintf_cb)(int c, void *ctx);
296#else
297typedef int (*cbprintf_cb)(/* int c, void *ctx */);
298#endif
299
308typedef int (*cbprintf_convert_cb)(const void *buf, size_t len, void *ctx);
309
328typedef int (*cbvprintf_external_formatter_func)(cbprintf_cb out, void *ctx,
329 const char *fmt, va_list ap);
330
348#define CBPRINTF_MUST_RUNTIME_PACKAGE(flags, ... /* fmt, ... */) \
349 Z_CBPRINTF_MUST_RUNTIME_PACKAGE(flags, __VA_ARGS__)
350
380#define CBPRINTF_STATIC_PACKAGE(packaged, inlen, outlen, align_offset, flags, \
381 ... /* fmt, ... */) \
382 Z_CBPRINTF_STATIC_PACKAGE(packaged, inlen, outlen, \
383 align_offset, flags, __VA_ARGS__)
384
425__printf_like(4, 5)
426int cbprintf_package(void *packaged,
427 size_t len,
429 const char *format,
430 ...);
431
466int cbvprintf_package(void *packaged,
467 size_t len,
469 const char *format,
470 va_list ap);
471
507int cbprintf_package_convert(void *in_packaged,
508 size_t in_len,
510 void *ctx,
512 uint16_t *strl,
513 size_t strl_len);
514
515/* @interal Context used for package copying. */
516struct z_cbprintf_buf_desc {
517 void *buf;
518 size_t size;
519 size_t off;
520};
521
522/* @internal Function callback used for package copying. */
523static inline int z_cbprintf_cpy(const void *buf, size_t len, void *ctx)
524{
525 struct z_cbprintf_buf_desc *desc = (struct z_cbprintf_buf_desc *)ctx;
526
527 if ((desc->size - desc->off) < len) {
528 return -ENOSPC;
529 }
530
531 memcpy(&((uint8_t *)desc->buf)[desc->off], buf, len);
532 desc->off += len;
533
534 return len;
535}
536
567static inline int cbprintf_package_copy(void *in_packaged,
568 size_t in_len,
569 void *packaged,
570 size_t len,
572 uint16_t *strl,
573 size_t strl_len)
574{
575 struct z_cbprintf_buf_desc buf_desc = {
576 .buf = packaged,
577 .size = len,
578 .off = 0,
579 };
580
581 return cbprintf_package_convert(in_packaged, in_len,
582 packaged ? z_cbprintf_cpy : NULL, &buf_desc,
583 flags, strl, strl_len);
584}
585
615static inline int cbprintf_fsc_package(void *in_packaged,
616 size_t in_len,
617 void *packaged,
618 size_t len)
619{
620 return cbprintf_package_copy(in_packaged, in_len, packaged, len,
623}
624
647 void *ctx,
648 void *packaged);
649
676__printf_like(3, 4)
677int cbprintf(cbprintf_cb out, void *ctx, const char *format, ...);
678
707int z_cbvprintf_impl(cbprintf_cb out, void *ctx, const char *format,
708 va_list ap, uint32_t flags);
709
735#ifdef CONFIG_PICOLIBC
736int cbvprintf(cbprintf_cb out, void *ctx, const char *format, va_list ap);
737#else
738static inline
739int cbvprintf(cbprintf_cb out, void *ctx, const char *format, va_list ap)
740{
741 return z_cbvprintf_impl(out, ctx, format, ap, 0);
742}
743#endif
744
772static inline
774 const char *format, va_list ap)
775{
776 return z_cbvprintf_impl(out, ctx, format, ap,
777 Z_CBVPRINTF_PROCESS_FLAG_TAGGED_ARGS);
778}
779
797static inline
798int cbpprintf(cbprintf_cb out, void *ctx, void *packaged)
799{
800#if defined(CONFIG_CBPRINTF_PACKAGE_SUPPORT_TAGGED_ARGUMENTS)
801 union cbprintf_package_hdr *hdr =
802 (union cbprintf_package_hdr *)packaged;
803
804 if ((hdr->desc.pkg_flags & CBPRINTF_PACKAGE_ARGS_ARE_TAGGED)
807 ctx, packaged);
808 }
809#endif
810
811 return cbpprintf_external(out, cbvprintf, ctx, packaged);
812}
813
814#ifdef CONFIG_CBPRINTF_LIBC_SUBSTS
815
816#ifdef CONFIG_PICOLIBC
817
818#define fprintfcb(stream, ...) fprintf(stream, __VA_ARGS__)
819#define vfprintfcb(stream, format, ap) vfprintf(stream, format, ap)
820#define printfcb(format, ...) printf(format, __VA_ARGS__)
821#define vprintfcb(format, ap) vprintf(format, ap)
822#define snprintfcb(str, size, ...) snprintf(str, size, __VA_ARGS__)
823#define vsnprintfcb(str, size, format, ap) vsnprintf(str, size, format, ap)
824
825#else
826
845__printf_like(2, 3)
846int fprintfcb(FILE * stream, const char *format, ...);
847
865int vfprintfcb(FILE *stream, const char *format, va_list ap);
866
883__printf_like(1, 2)
884int printfcb(const char *format, ...);
885
901int vprintfcb(const char *format, va_list ap);
902
926__printf_like(3, 4)
927int snprintfcb(char *str, size_t size, const char *format, ...);
928
951int vsnprintfcb(char *str, size_t size, const char *format, va_list ap);
952
953#endif /* CONFIG_PICOLIBC */
954#endif /* CONFIG_CBPRINTF_LIBC_SUBSTS */
955
960#ifdef __cplusplus
961}
962#endif
963
964#endif /* ZEPHYR_INCLUDE_SYS_CBPRINTF_H_ */
irp nz macro MOVR cc s mov cc s endm endr irp aw macro LDR aa off
Definition: asm-macro-32-bit-gnu.h:17
#define CBPRINTF_PACKAGE_CONVERT_RO_STR
Append read-only strings from source package to destination package.
Definition: cbprintf.h:217
#define CBPRINTF_PACKAGE_CONVERT_RW_STR
Append read-write strings from source package to destination package.
Definition: cbprintf.h:230
#define CBPRINTF_PACKAGE_ARGS_ARE_TAGGED
Indicate the incoming arguments are tagged.
Definition: cbprintf.h:201
int cbprintf(cbprintf_cb out, void *ctx, const char *format,...)
*printf-like output through a callback.
int(* cbvprintf_external_formatter_func)(cbprintf_cb out, void *ctx, const char *fmt, va_list ap)
Signature for a external formatter function identical to cbvprintf.
Definition: cbprintf.h:328
static int cbpprintf(cbprintf_cb out, void *ctx, void *packaged)
Generate the output for a previously captured format operation.
Definition: cbprintf.h:798
int printfcb(const char *format,...)
printf using Zephyrs cbprintf infrastructure.
int vfprintfcb(FILE *stream, const char *format, va_list ap)
vfprintf using Zephyrs cbprintf infrastructure.
int fprintfcb(FILE *stream, const char *format,...)
fprintf using Zephyrs cbprintf infrastructure.
int vsnprintfcb(char *str, size_t size, const char *format, va_list ap)
vsnprintf using Zephyrs cbprintf infrastructure.
#define CBPRINTF_PACKAGE_ALIGNMENT
Required alignment of the buffer used for packaging.
Definition: cbprintf.h:140
int cbprintf_package_convert(void *in_packaged, size_t in_len, cbprintf_convert_cb cb, void *ctx, uint32_t flags, uint16_t *strl, size_t strl_len)
Convert a package.
static int cbprintf_fsc_package(void *in_packaged, size_t in_len, void *packaged, size_t len)
Convert package to fully self-contained (fsc) package.
Definition: cbprintf.h:615
int(* cbprintf_convert_cb)(const void *buf, size_t len, void *ctx)
Signature for a cbprintf multibyte callback function.
Definition: cbprintf.h:308
static int cbprintf_package_copy(void *in_packaged, size_t in_len, void *packaged, size_t len, uint32_t flags, uint16_t *strl, size_t strl_len)
Copy package with optional appending of strings.
Definition: cbprintf.h:567
static int cbvprintf(cbprintf_cb out, void *ctx, const char *format, va_list ap)
varargs-aware *printf-like output through a callback.
Definition: cbprintf.h:739
int snprintfcb(char *str, size_t size, const char *format,...)
snprintf using Zephyrs cbprintf infrastructure.
int cbpprintf_external(cbprintf_cb out, cbvprintf_external_formatter_func formatter, void *ctx, void *packaged)
Generate the output for a previously captured format operation using an external formatter.
int vprintfcb(const char *format, va_list ap)
vprintf using Zephyrs cbprintf infrastructure.
int cbvprintf_package(void *packaged, size_t len, uint32_t flags, const char *format, va_list ap)
Capture state required to output formatted data later.
int(* cbprintf_cb)()
Signature for a cbprintf callback function.
Definition: cbprintf.h:297
int cbprintf_package(void *packaged, size_t len, uint32_t flags, const char *format,...)
Capture state required to output formatted data later.
static int cbvprintf_tagged_args(cbprintf_cb out, void *ctx, const char *format, va_list ap)
varargs-aware *printf-like output through a callback with tagged arguments.
Definition: cbprintf.h:773
#define ENOSPC
Definition: errno.h:67
flags
Definition: parser.h:96
char c
Definition: printk.c:112
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
__UINT16_TYPE__ uint16_t
Definition: stdint.h:89
int FILE
Definition: stdio.h:22
void * memcpy(void *ZRESTRICT d, const void *ZRESTRICT s, size_t n)
cbprintf package descriptor.
Definition: cbprintf.h:45
uint8_t len
Definition: cbprintf.h:47
uint8_t str_cnt
Definition: cbprintf.h:50
uint8_t ro_str_cnt
Definition: cbprintf.h:53
uint8_t rw_str_cnt
Definition: cbprintf.h:56
cbprintf package header with format string pointer.
Definition: cbprintf.h:96
union cbprintf_package_hdr hdr
Definition: cbprintf.h:98
char * fmt
Definition: cbprintf.h:101
Macros to abstract toolchain specific capabilities.
cbprintf package header
Definition: cbprintf.h:78
void * raw
Definition: cbprintf.h:82
struct cbprintf_package_desc desc
Definition: cbprintf.h:80