/*
* Copyright (C) 2015 The Android Open Source Project
*
* 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
*
* http://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.
*/
#ifndef ANDROID_RADIO_METADATA_HIDDEN_H
#define ANDROID_RADIO_METADATA_HIDDEN_H
#include <stdbool.h>
#include <system/radio.h>
#include <system/radio_metadata.h>
/* default size allocated for a metadata buffer in 32 bits units */
#define RADIO_METADATA_DEFAULT_SIZE 64
/* maximum size allocated for a metadata buffer in 32 bits units */
#define RADIO_METADATA_MAX_SIZE (RADIO_METADATA_DEFAULT_SIZE << 12)
/* meta data entry in a meta data buffer */
typedef struct radio_metadata_entry {
radio_metadata_key_t key;
radio_metadata_type_t type;
uint32_t size;
uint8_t data[];
} radio_metadata_entry_t;
/**
* meta data buffer layout:
*
* | <--- 32 bit ---> |
* |---------------------------|
* | channel |
* |---------------------------|
* | sub_channel |
* |---------------------------|
* | size_int | total size in 32 bit units including header and index
* |---------------------------|
* | count | number of entries
* |---------------------------|<--+
* | first entry | |
* | | |
* |---------------------------|<+ |
* | second entry | | |
* | | | |
* | | | |
* |---------------------------| | |
* | : | | |
* |---------------------------| | | \
* | offset of next free space | | | |
* |---------------------------| | | |
* | : | | | |
* |---------------------------| | | > index
* | offset of second entry |-+ | |
* |---------------------------| | |
* | offset of first entry |---+ |
* |---------------------------| /
*
* A radio meta data buffer is allocated with radio_metadata_allocate() and released with
* radio_metadata_deallocate().
* Meta data entries are added with radio_metadata_add_xxx() where xxx is int, text or raw.
* The buffer is allocated with a default size (RADIO_METADATA_DEFAULT_SIZE entries)
* by radio_metadata_allocate() and reallocated if needed by radio_metadata_add_xxx()
*/
/* Radio meta data buffer header */
typedef struct radio_metadata_buffer {
uint32_t channel; /* channel (frequency) this meta data is associated with */
uint32_t sub_channel; /* sub channel this meta data is associated with */
uint32_t size_int; /* Total size in 32 bit word units */
uint32_t count; /* number of meta data entries */
} radio_metadata_buffer_t;
#endif // ANDROID_RADIO_METADATA_HIDDEN_H