Zephyr Project API 4.1.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
log_frontend_stmesp_demux.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2024 Nordic Semiconductor ASA
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#ifndef ZEPHYR_INCLUDE_LOGGING_LOG_FRONTEND_STMESP_DEMUX_H_
8#define ZEPHYR_INCLUDE_LOGGING_LOG_FRONTEND_STMESP_DEMUX_H_
9
10#include <zephyr/kernel.h>
12
13#ifdef __cplusplus
14extern "C" {
15#endif
16
28#define LOG_FRONTEND_STMESP_DEMUX_MAJOR_BITS 3
29
31#define LOG_FRONTEND_STMESP_DEMUX_LEVEL_BITS 3
32
34#define LOG_FRONTEND_STMESP_DEMUX_TLENGTH_BITS 16
35
37#define LOG_FRONTEND_STMESP_DEMUX_PLENGTH_BITS 10
38
40#define LOG_FRONTEND_STMESP_DEMUX_MAJOR_MAX BIT(LOG_FRONTEND_STMESP_DEMUX_MAJOR_BITS)
41
43#define LOG_FRONTEND_STMESP_DEMUX_TYPE_LOG 0
44
46#define LOG_FRONTEND_STMESP_DEMUX_TYPE_TRACE_POINT 1
47
49#define LOG_FRONTEND_STMESP_DEMUX_TYPE_HW_EVENT 2
50
65
74
86
110
140
158
179
194
203
209
215
222
229
235
244
251
254
262
271
279
295
302
305
312
317#ifdef __cplusplus
318}
319#endif
320
321#endif /* ZEPHYR_INCLUDE_LOGGING_LOG_FRONTEND_STMESP_DEMUX_H_ */
const char * log_frontend_stmesp_demux_sname_get(uint32_t m_id, uint16_t s_id)
Get source name for a turbo log message.
void log_frontend_stmesp_demux_timestamp(uint64_t ts)
Indicate timestamp.
bool log_frontend_stmesp_demux_is_idle(void)
Check if there are any started but not completed log messages.
void log_frontend_stmesp_demux_data(uint8_t *data, size_t len)
Indicate data.
#define LOG_FRONTEND_STMESP_DEMUX_MAJOR_BITS
Bits used to store major index.
Definition log_frontend_stmesp_demux.h:28
void log_frontend_stmesp_demux_packet_end(void)
Indicate packet end (Flag).
void log_frontend_stmesp_demux_reset(void)
Close any opened messages and mark them as invalid.
void log_frontend_stmesp_demux_channel(uint16_t id)
Indicate channel opcode in the STPv2 stream.
#define LOG_FRONTEND_STMESP_DEMUX_PLENGTH_BITS
Bits used to store package length.
Definition log_frontend_stmesp_demux.h:37
int log_frontend_stmesp_demux_log0(uint16_t source_id, uint64_t *ts)
Indicate optimized log message with no arguments.
int log_frontend_stmesp_demux_max_utilization(void)
Get maximum buffer utilization.
const char * log_frontend_stmesp_demux_str_get(uint32_t m_id, uint16_t s_id)
void log_frontend_stmesp_demux_major(uint16_t id)
Indicate major opcode in the STPv2 stream.
int log_frontend_stmesp_demux_init(const struct log_frontend_stmesp_demux_config *config)
Initialize the demultiplexer.
uint32_t log_frontend_stmesp_demux_get_dropped(void)
Get number of dropped messages and reset the counter.
void log_frontend_stmesp_demux_free(union log_frontend_stmesp_demux_packet packet)
Free previously claimed packet.
void log_frontend_stmesp_demux_source_id(uint16_t source_id)
Indicate source ID.
#define LOG_FRONTEND_STMESP_DEMUX_TLENGTH_BITS
Bits used to store total length.
Definition log_frontend_stmesp_demux.h:34
int log_frontend_stmesp_demux_packet_start(uint32_t *data, uint64_t *ts)
Indicate detected packet start (DMTS).
#define LOG_FRONTEND_STMESP_DEMUX_LEVEL_BITS
Bits used to store severity level.
Definition log_frontend_stmesp_demux.h:31
union log_frontend_stmesp_demux_packet log_frontend_stmesp_demux_claim(void)
Claim packet.
Public kernel APIs.
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT64_TYPE__ uint64_t
Definition stdint.h:91
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Demultiplexer configuration.
Definition log_frontend_stmesp_demux.h:181
size_t source_id_buf_len
It must be multiple of number of major ID's count.
Definition log_frontend_stmesp_demux.h:192
uint32_t * source_id_buf
Buffer for storing source ID's.
Definition log_frontend_stmesp_demux.h:189
uint32_t m_ids_cnt
Array length.
Definition log_frontend_stmesp_demux.h:186
const uint16_t * m_ids
Array with expected major ID's.
Definition log_frontend_stmesp_demux.h:183
Packet with HW event.
Definition log_frontend_stmesp_demux.h:142
uint64_t timestamp
Timestamp.
Definition log_frontend_stmesp_demux.h:153
uint8_t evt
HW event ID.
Definition log_frontend_stmesp_demux.h:156
uint64_t type
Type.
Definition log_frontend_stmesp_demux.h:147
MPSC_PBUF_HDR
Data for MPSC packet handling.
Definition log_frontend_stmesp_demux.h:144
uint64_t content_invalid
Flag indicating if packet is valid.
Definition log_frontend_stmesp_demux.h:150
Logging message header.
Definition log_frontend_stmesp_demux.h:52
uint32_t package_len
Hexdump data length.
Definition log_frontend_stmesp_demux.h:63
uint32_t total_len
Total length excluding this header.
Definition log_frontend_stmesp_demux.h:60
uint32_t level
Severity level.
Definition log_frontend_stmesp_demux.h:57
uint32_t major
Major index.
Definition log_frontend_stmesp_demux.h:54
Packet with logging message.
Definition log_frontend_stmesp_demux.h:88
uint64_t content_invalid
Flag indicating if packet is valid.
Definition log_frontend_stmesp_demux.h:96
struct log_frontend_stmesp_demux_log_header hdr
Logging header.
Definition log_frontend_stmesp_demux.h:102
uint32_t padding
Padding so that data is 8 bytes aligned.
Definition log_frontend_stmesp_demux.h:105
MPSC_PBUF_HDR
Data for MPSC packet handling.
Definition log_frontend_stmesp_demux.h:90
uint64_t type
Type.
Definition log_frontend_stmesp_demux.h:93
uint8_t data[]
Content.
Definition log_frontend_stmesp_demux.h:108
uint64_t timestamp
Timestamp.
Definition log_frontend_stmesp_demux.h:99
Generic STP demux packet.
Definition log_frontend_stmesp_demux.h:76
uint64_t content_invalid
Flag indicating if packet is valid.
Definition log_frontend_stmesp_demux.h:84
uint64_t type
Type.
Definition log_frontend_stmesp_demux.h:81
MPSC_PBUF_HDR
Data for MPSC packet handling.
Definition log_frontend_stmesp_demux.h:78
Packet with trace point.
Definition log_frontend_stmesp_demux.h:112
uint64_t has_data
Flag indicating if trace point includes data.
Definition log_frontend_stmesp_demux.h:123
uint16_t source_id
Source ID - used for compressed logging.
Definition log_frontend_stmesp_demux.h:132
uint64_t content_invalid
Flag indicating if packet is valid.
Definition log_frontend_stmesp_demux.h:120
uint64_t timestamp
Timestamp.
Definition log_frontend_stmesp_demux.h:126
uint64_t type
Type.
Definition log_frontend_stmesp_demux.h:117
uint64_t major
Major ID.
Definition log_frontend_stmesp_demux.h:129
uint32_t data
Content.
Definition log_frontend_stmesp_demux.h:138
MPSC_PBUF_HDR
Data for MPSC packet handling.
Definition log_frontend_stmesp_demux.h:114
uint16_t id
ID.
Definition log_frontend_stmesp_demux.h:135
Union for writing raw data to the logging message header.
Definition log_frontend_stmesp_demux.h:67
uint32_t raw
Raw word.
Definition log_frontend_stmesp_demux.h:72
struct log_frontend_stmesp_demux_log_header log
Log header structure.
Definition log_frontend_stmesp_demux.h:69
Union of all packet types.
Definition log_frontend_stmesp_demux.h:160
struct log_frontend_stmesp_demux_packet_generic * generic_packet
Pointer to the generic log_frontend_stmesp_demux packet.
Definition log_frontend_stmesp_demux.h:177
struct log_frontend_stmesp_demux_trace_point * trace_point
Pointer to the trace point message.
Definition log_frontend_stmesp_demux.h:171
const union mpsc_pbuf_generic * rgeneric
Pointer to generic mpsc_pbuf const packet.
Definition log_frontend_stmesp_demux.h:162
struct log_frontend_stmesp_demux_log * log
Pointer to the log message.
Definition log_frontend_stmesp_demux.h:168
struct log_frontend_stmesp_demux_hw_event * hw_event
Pointer to the HW event message.
Definition log_frontend_stmesp_demux.h:174
Generic packet header.
Definition mpsc_packet.h:49