/* 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_ */