// Copyright 2020 The Pigweed Authors // // Licensed under the Apache License, Version 2.0 (the "License"); you may not // use this file except in compliance with the License. You may obtain a copy of // the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the // License for the specific language governing permissions and limitations under // the License. // This file defines the functions that encode tokenized logs at runtime. These // are the only pw_tokenizer functions present in a binary that tokenizes // strings. All other tokenizing code is resolved at compile time. #include "pw_tokenizer/tokenize.h" #include #include "pw_tokenizer_private/encode_args.h" namespace pw { namespace tokenizer { namespace { // Store metadata about this compilation's string tokenization in the ELF. // // The tokenizer metadata will not go into the on-device executable binary code. // This metadata will be present in the ELF file's .pw_tokenizer.info section, // from which the host-side tooling (Python, Java, etc.) can understand how to // decode tokenized strings for the given binary. Only attributes that affect // the decoding process are recorded. // // Tokenizer metadata is stored in an array of key-value pairs. Each Metadata // object is 32 bytes: a 24-byte string and an 8-byte value. Metadata structs // may be parsed in Python with the struct format '24s(static_cast(buffer) + sizeof(token), *buffer_size_bytes - sizeof(token))); va_end(args); *buffer_size_bytes = sizeof(token) + encoded_bytes; } extern "C" void _pw_tokenizer_ToCallback( void (*callback)(const uint8_t* encoded_message, size_t size_bytes), Token token, _pw_tokenizer_ArgTypes types, ...) { EncodedMessage encoded; encoded.token = token; va_list args; va_start(args, types); const size_t encoded_bytes = EncodeArgs(types, args, encoded.args); va_end(args); callback(reinterpret_cast(&encoded), sizeof(encoded.token) + encoded_bytes); } } // namespace tokenizer } // namespace pw