162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */
262306a36Sopenharmony_ci#ifndef __SOUND_PCM_OSS_H
362306a36Sopenharmony_ci#define __SOUND_PCM_OSS_H
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci/*
662306a36Sopenharmony_ci *  Digital Audio (PCM) - OSS compatibility abstract layer
762306a36Sopenharmony_ci *  Copyright (c) by Jaroslav Kysela <perex@perex.cz>
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci
1062306a36Sopenharmony_cistruct snd_pcm_oss_setup {
1162306a36Sopenharmony_ci	char *task_name;
1262306a36Sopenharmony_ci	unsigned int disable:1,
1362306a36Sopenharmony_ci		     direct:1,
1462306a36Sopenharmony_ci		     block:1,
1562306a36Sopenharmony_ci		     nonblock:1,
1662306a36Sopenharmony_ci		     partialfrag:1,
1762306a36Sopenharmony_ci		     nosilence:1,
1862306a36Sopenharmony_ci		     buggyptr:1;
1962306a36Sopenharmony_ci	unsigned int periods;
2062306a36Sopenharmony_ci	unsigned int period_size;
2162306a36Sopenharmony_ci	struct snd_pcm_oss_setup *next;
2262306a36Sopenharmony_ci};
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_cistruct snd_pcm_oss_runtime {
2562306a36Sopenharmony_ci	unsigned params: 1,			/* format/parameter change */
2662306a36Sopenharmony_ci		 prepare: 1,			/* need to prepare the operation */
2762306a36Sopenharmony_ci		 trigger: 1,			/* trigger flag */
2862306a36Sopenharmony_ci		 sync_trigger: 1;		/* sync trigger flag */
2962306a36Sopenharmony_ci	int rate;				/* requested rate */
3062306a36Sopenharmony_ci	int format;				/* requested OSS format */
3162306a36Sopenharmony_ci	unsigned int channels;			/* requested channels */
3262306a36Sopenharmony_ci	unsigned int fragshift;
3362306a36Sopenharmony_ci	unsigned int maxfrags;
3462306a36Sopenharmony_ci	unsigned int subdivision;		/* requested subdivision */
3562306a36Sopenharmony_ci	size_t period_bytes;			/* requested period size */
3662306a36Sopenharmony_ci	size_t period_frames;			/* period frames for poll */
3762306a36Sopenharmony_ci	size_t period_ptr;			/* actual write pointer to period */
3862306a36Sopenharmony_ci	unsigned int periods;
3962306a36Sopenharmony_ci	size_t buffer_bytes;			/* requested buffer size */
4062306a36Sopenharmony_ci	size_t bytes;				/* total # bytes processed */
4162306a36Sopenharmony_ci	size_t mmap_bytes;
4262306a36Sopenharmony_ci	char *buffer;				/* vmallocated period */
4362306a36Sopenharmony_ci	size_t buffer_used;			/* used length from period buffer */
4462306a36Sopenharmony_ci	struct mutex params_lock;
4562306a36Sopenharmony_ci	atomic_t rw_ref;		/* concurrent read/write accesses */
4662306a36Sopenharmony_ci#ifdef CONFIG_SND_PCM_OSS_PLUGINS
4762306a36Sopenharmony_ci	struct snd_pcm_plugin *plugin_first;
4862306a36Sopenharmony_ci	struct snd_pcm_plugin *plugin_last;
4962306a36Sopenharmony_ci#endif
5062306a36Sopenharmony_ci	unsigned int prev_hw_ptr_period;
5162306a36Sopenharmony_ci};
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_cistruct snd_pcm_oss_file {
5462306a36Sopenharmony_ci	struct snd_pcm_substream *streams[2];
5562306a36Sopenharmony_ci};
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_cistruct snd_pcm_oss_substream {
5862306a36Sopenharmony_ci	unsigned oss: 1;			/* oss mode */
5962306a36Sopenharmony_ci	struct snd_pcm_oss_setup setup;		/* active setup */
6062306a36Sopenharmony_ci};
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_cistruct snd_pcm_oss_stream {
6362306a36Sopenharmony_ci	struct snd_pcm_oss_setup *setup_list;	/* setup list */
6462306a36Sopenharmony_ci	struct mutex setup_mutex;
6562306a36Sopenharmony_ci#ifdef CONFIG_SND_VERBOSE_PROCFS
6662306a36Sopenharmony_ci	struct snd_info_entry *proc_entry;
6762306a36Sopenharmony_ci#endif
6862306a36Sopenharmony_ci};
6962306a36Sopenharmony_ci
7062306a36Sopenharmony_cistruct snd_pcm_oss {
7162306a36Sopenharmony_ci	int reg;
7262306a36Sopenharmony_ci	unsigned int reg_mask;
7362306a36Sopenharmony_ci};
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ci#endif /* __SOUND_PCM_OSS_H */
76