| /* Copyright (c) 2014 The Chromium OS Authors. All rights reserved. |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| */ |
| |
| #ifndef BUFFER_SHARE_H_ |
| #define BUFFER_SHARE_H_ |
| |
| #define INITIAL_ID_SIZE 3 |
| |
| struct id_offset { |
| unsigned int used; |
| unsigned int id; |
| unsigned int offset; |
| void *data; |
| }; |
| |
| struct buffer_share { |
| unsigned int buf_sz; |
| unsigned int id_sz; |
| struct id_offset *wr_idx; |
| }; |
| |
| /* |
| * Creates a buffer share object. This object is used to manage the read or |
| * write offsets of several users in one shared buffer. |
| */ |
| struct buffer_share *buffer_share_create(unsigned int buf_sz); |
| |
| /* Destroys a buffer_share returned from buffer_share_create. */ |
| void buffer_share_destroy(struct buffer_share *mix); |
| |
| /* Adds an ID that shares the buffer. */ |
| int buffer_share_add_id(struct buffer_share *mix, unsigned int id, void *data); |
| |
| /* Removes an ID that shares the buffer. */ |
| int buffer_share_rm_id(struct buffer_share *mix, unsigned int id); |
| |
| /* Updates the offset of the given user into the shared buffer. */ |
| int buffer_share_offset_update(struct buffer_share *mix, unsigned int id, |
| unsigned int frames); |
| |
| /* |
| * Updates the write point to the minimum offset from all users. |
| * Returns the number of minimum number of frames written. |
| */ |
| unsigned int buffer_share_get_new_write_point(struct buffer_share *mix); |
| |
| /* |
| * The amount by which the user given by id is ahead of the current write |
| * point. |
| */ |
| unsigned int buffer_share_id_offset(const struct buffer_share *mix, |
| unsigned int id); |
| |
| /* |
| * Gets the data pointer for given id. |
| */ |
| void *buffer_share_get_data(const struct buffer_share *mix, unsigned int id); |
| |
| #endif /* BUFFER_SHARE_H_ */ |