/* * compress_driver.h - compress offload driver definations * * Copyright (C) 2011 Intel Corporation * Authors: Vinod Koul <vinod.koul@linux.intel.com> * Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com> * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; version 2 of the License. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. * * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * */ #ifndef __COMPRESS_DRIVER_H #define __COMPRESS_DRIVER_H #include <linux/types.h> #include <linux/sched.h> #include <sound/core.h> #include <sound/compress_offload.h> #include <sound/asound.h> #include <sound/pcm.h> struct snd_compr_ops; /** * struct snd_compr_runtime: runtime stream description * @state: stream state * @ops: pointer to DSP callbacks * @buffer: pointer to kernel buffer, valid only when not in mmap mode or * DSP doesn't implement copy * @buffer_size: size of the above buffer * @fragment_size: size of buffer fragment in bytes * @fragments: number of such fragments * @total_bytes_available: cumulative number of bytes made available in * the ring buffer * @total_bytes_transferred: cumulative bytes transferred by offload DSP * @sleep: poll sleep * @private_data: driver private data pointer */ struct snd_compr_runtime { snd_pcm_state_t state; struct snd_compr_ops *ops; void *buffer; u64 buffer_size; u32 fragment_size; u32 fragments; u64 total_bytes_available; u64 total_bytes_transferred; wait_queue_head_t sleep; void *private_data; }; /** * struct snd_compr_stream: compressed stream * @name: device name * @ops: pointer to DSP callbacks * @runtime: pointer to runtime structure * @device: device pointer * @error_work: delayed work used when closing the stream due to an error * @direction: stream direction, playback/recording * @metadata_set: metadata set flag, true when set * @next_track: has userspace signal next track transition, true when set * @partial_drain: undergoing partial_drain for stream, true when set * @private_data: pointer to DSP private data */ struct snd_compr_stream { const char *name; struct snd_compr_ops *ops; struct snd_compr_runtime *runtime; struct snd_compr *device; struct delayed_work error_work; enum snd_compr_direction direction; bool metadata_set; bool next_track; bool partial_drain; void *private_data; }; /** * struct snd_compr_ops: compressed path DSP operations * @open: Open the compressed stream * This callback is mandatory and shall keep dsp ready to receive the stream * parameter * @free: Close the compressed stream, mandatory * @set_params: Sets the compressed stream parameters, mandatory * This can be called in during stream creation only to set codec params * and the stream properties * @get_params: retrieve the codec parameters, mandatory * @set_metadata: Set the metadata values for a stream * @get_metadata: retrieves the requested metadata values from stream * @trigger: Trigger operations like start, pause, resume, drain, stop. * This callback is mandatory * @pointer: Retrieve current h/w pointer information. Mandatory * @copy: Copy the compressed data to/from userspace, Optional * Can't be implemented if DSP supports mmap * @mmap: DSP mmap method to mmap DSP memory * @ack: Ack for DSP when data is written to audio buffer, Optional * Not valid if copy is implemented * @get_caps: Retrieve DSP capabilities, mandatory * @get_codec_caps: Retrieve capabilities for a specific codec, mandatory */ struct snd_compr_ops { int (*open)(struct snd_compr_stream *stream); int (*free)(struct snd_compr_stream *stream); int (*set_params)(struct snd_compr_stream *stream, struct snd_compr_params *params); int (*get_params)(struct snd_compr_stream *stream, struct snd_codec *params); int (*set_metadata)(struct snd_compr_stream *stream, struct snd_compr_metadata *metadata); int (*get_metadata)(struct snd_compr_stream *stream, struct snd_compr_metadata *metadata); int (*trigger)(struct snd_compr_stream *stream, int cmd); int (*pointer)(struct snd_compr_stream *stream, struct snd_compr_tstamp *tstamp); int (*copy)(struct snd_compr_stream *stream, char __user *buf, size_t count); int (*mmap)(struct snd_compr_stream *stream, struct vm_area_struct *vma); int (*ack)(struct snd_compr_stream *stream, size_t bytes); int (*get_caps) (struct snd_compr_stream *stream, struct snd_compr_caps *caps); int (*get_codec_caps) (struct snd_compr_stream *stream, struct snd_compr_codec_caps *codec); }; /** * struct snd_compr: Compressed device * @name: DSP device name * @dev: associated device instance * @ops: pointer to DSP callbacks * @private_data: pointer to DSP pvt data * @card: sound card pointer * @direction: Playback or capture direction * @lock: device lock * @device: device id */ struct snd_compr { const char *name; struct device dev; struct snd_compr_ops *ops; void *private_data; struct snd_card *card; unsigned int direction; struct mutex lock; int device; #ifdef CONFIG_SND_VERBOSE_PROCFS /* private: */ char id[64]; struct snd_info_entry *proc_root; struct snd_info_entry *proc_info_entry; #endif }; /* compress device register APIs */ int snd_compress_register(struct snd_compr *device); int snd_compress_deregister(struct snd_compr *device); int snd_compress_new(struct snd_card *card, int device, int type, const char *id, struct snd_compr *compr); /* dsp driver callback apis * For playback: driver should call snd_compress_fragment_elapsed() to let the * framework know that a fragment has been consumed from the ring buffer * * For recording: we want to know when a frame is available or when * at least one frame is available so snd_compress_frame_elapsed() * callback should be called when a encodeded frame is available */ static inline void snd_compr_fragment_elapsed(struct snd_compr_stream *stream) { wake_up(&stream->runtime->sleep); } static inline void snd_compr_drain_notify(struct snd_compr_stream *stream) { if (snd_BUG_ON(!stream)) return; /* for partial_drain case we are back to running state on success */ if (stream->partial_drain) { stream->runtime->state = SNDRV_PCM_STATE_RUNNING; stream->partial_drain = false; /* clear this flag as well */ } else { stream->runtime->state = SNDRV_PCM_STATE_SETUP; } wake_up(&stream->runtime->sleep); } int snd_compr_stop_error(struct snd_compr_stream *stream, snd_pcm_state_t state); #endif
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
ac97 | Folder | 0755 |
|
|
ac97_codec.h | File | 16.34 KB | 0644 |
|
aci.h | File | 2.4 KB | 0644 |
|
ad1816a.h | File | 5.38 KB | 0644 |
|
ad1843.h | File | 1.48 KB | 0644 |
|
adau1373.h | File | 699 B | 0644 |
|
aess.h | File | 1.63 KB | 0644 |
|
ak4113.h | File | 10.89 KB | 0644 |
|
ak4114.h | File | 10.22 KB | 0644 |
|
ak4117.h | File | 9.02 KB | 0644 |
|
ak4531_codec.h | File | 3.1 KB | 0644 |
|
ak4641.h | File | 622 B | 0644 |
|
ak4xxx-adda.h | File | 3.34 KB | 0644 |
|
alc5623.h | File | 536 B | 0644 |
|
asequencer.h | File | 3.58 KB | 0644 |
|
asound.h | File | 1.25 KB | 0644 |
|
asoundef.h | File | 16.7 KB | 0644 |
|
compress_driver.h | File | 6.93 KB | 0644 |
|
control.h | File | 8.84 KB | 0644 |
|
core.h | File | 13.84 KB | 0644 |
|
cs35l33.h | File | 1.01 KB | 0644 |
|
cs35l34.h | File | 887 B | 0644 |
|
cs35l35.h | File | 2.36 KB | 0644 |
|
cs4231-regs.h | File | 8.28 KB | 0644 |
|
cs4271.h | File | 1.38 KB | 0644 |
|
cs42l52.h | File | 738 B | 0644 |
|
cs42l56.h | File | 1.16 KB | 0644 |
|
cs42l73.h | File | 507 B | 0644 |
|
cs8403.h | File | 8.63 KB | 0644 |
|
cs8427.h | File | 10.4 KB | 0644 |
|
da7213.h | File | 1.15 KB | 0644 |
|
da7218.h | File | 2.62 KB | 0644 |
|
da7219-aad.h | File | 2.42 KB | 0644 |
|
da7219.h | File | 1.04 KB | 0644 |
|
da9055.h | File | 914 B | 0644 |
|
designware_i2s.h | File | 2.25 KB | 0644 |
|
dmaengine_pcm.h | File | 6.22 KB | 0644 |
|
emu10k1.h | File | 89.25 KB | 0644 |
|
emu10k1_synth.h | File | 1.35 KB | 0644 |
|
emu8000.h | File | 4.01 KB | 0644 |
|
emu8000_reg.h | File | 10.21 KB | 0644 |
|
emux_legacy.h | File | 5.37 KB | 0644 |
|
emux_synth.h | File | 7.46 KB | 0644 |
|
es1688.h | File | 3.53 KB | 0644 |
|
gus.h | File | 20.21 KB | 0644 |
|
hda_chmap.h | File | 2.6 KB | 0644 |
|
hda_hwdep.h | File | 1.38 KB | 0644 |
|
hda_i915.h | File | 1.64 KB | 0644 |
|
hda_register.h | File | 10 KB | 0644 |
|
hda_regmap.h | File | 6.59 KB | 0644 |
|
hda_verbs.h | File | 16.81 KB | 0644 |
|
hdaudio.h | File | 18.39 KB | 0644 |
|
hdaudio_ext.h | File | 6.99 KB | 0644 |
|
hdmi-codec.h | File | 2.42 KB | 0644 |
|
hwdep.h | File | 2.56 KB | 0644 |
|
i2c.h | File | 3.47 KB | 0644 |
|
info.h | File | 7.41 KB | 0644 |
|
initval.h | File | 3.08 KB | 0644 |
|
jack.h | File | 3.75 KB | 0644 |
|
l3.h | File | 524 B | 0644 |
|
max9768.h | File | 729 B | 0644 |
|
max98088.h | File | 1.26 KB | 0644 |
|
max98090.h | File | 754 B | 0644 |
|
max98095.h | File | 1.54 KB | 0644 |
|
memalloc.h | File | 4.41 KB | 0644 |
|
minors.h | File | 4.33 KB | 0644 |
|
mixer_oss.h | File | 2.41 KB | 0644 |
|
mpu401.h | File | 4.49 KB | 0644 |
|
omap-hdmi-audio.h | File | 1.34 KB | 0644 |
|
omap-pcm.h | File | 864 B | 0644 |
|
opl3.h | File | 12.31 KB | 0644 |
|
opl4.h | File | 1.1 KB | 0644 |
|
pcm-indirect.h | File | 5.7 KB | 0644 |
|
pcm.h | File | 47.51 KB | 0644 |
|
pcm_drm_eld.h | File | 183 B | 0644 |
|
pcm_iec958.h | File | 332 B | 0644 |
|
pcm_oss.h | File | 2.69 KB | 0644 |
|
pcm_params.h | File | 9.03 KB | 0644 |
|
pt2258.h | File | 1.18 KB | 0644 |
|
pxa2xx-lib.h | File | 1.48 KB | 0644 |
|
rawmidi.h | File | 6.17 KB | 0644 |
|
rt286.h | File | 460 B | 0644 |
|
rt298.h | File | 519 B | 0644 |
|
rt5514.h | File | 478 B | 0644 |
|
rt5640.h | File | 648 B | 0644 |
|
rt5645.h | File | 738 B | 0644 |
|
rt5651.h | File | 581 B | 0644 |
|
rt5659.h | File | 1003 B | 0644 |
|
rt5660.h | File | 724 B | 0644 |
|
rt5663.h | File | 622 B | 0644 |
|
rt5665.h | File | 907 B | 0644 |
|
rt5670.h | File | 679 B | 0644 |
|
s3c24xx_uda134x.h | File | 229 B | 0644 |
|
sb.h | File | 10.98 KB | 0644 |
|
sb16_csp.h | File | 2.71 KB | 0644 |
|
seq_device.h | File | 2.79 KB | 0644 |
|
seq_kernel.h | File | 3.96 KB | 0644 |
|
seq_midi_emul.h | File | 7.26 KB | 0644 |
|
seq_midi_event.h | File | 2.17 KB | 0644 |
|
seq_oss.h | File | 2.86 KB | 0644 |
|
seq_oss_legacy.h | File | 1 KB | 0644 |
|
seq_virmidi.h | File | 2.73 KB | 0644 |
|
sh_dac_audio.h | File | 587 B | 0644 |
|
sh_fsi.h | File | 847 B | 0644 |
|
simple_card.h | File | 683 B | 0644 |
|
simple_card_utils.h | File | 3.96 KB | 0644 |
|
snd_wavefront.h | File | 5.57 KB | 0644 |
|
soc-acpi-intel-match.h | File | 1.1 KB | 0644 |
|
soc-acpi.h | File | 3.6 KB | 0644 |
|
soc-dai.h | File | 11.13 KB | 0644 |
|
soc-dapm.h | File | 30.87 KB | 0644 |
|
soc-dpcm.h | File | 4.73 KB | 0644 |
|
soc-topology.h | File | 5.71 KB | 0644 |
|
soc.h | File | 63.47 KB | 0644 |
|
soundfont.h | File | 4.48 KB | 0644 |
|
spear_dma.h | File | 1003 B | 0644 |
|
spear_spdif.h | File | 1010 B | 0644 |
|
sta32x.h | File | 1.2 KB | 0644 |
|
sta350.h | File | 1.65 KB | 0644 |
|
tas2552-plat.h | File | 678 B | 0644 |
|
tas5086.h | File | 210 B | 0644 |
|
tea6330t.h | File | 1.14 KB | 0644 |
|
timer.h | File | 5.56 KB | 0644 |
|
tlv.h | File | 2.27 KB | 0644 |
|
tlv320aic32x4.h | File | 1.43 KB | 0644 |
|
tlv320aic3x.h | File | 1.88 KB | 0644 |
|
tlv320dac33-plat.h | File | 720 B | 0644 |
|
tpa6130a2-plat.h | File | 900 B | 0644 |
|
uda134x.h | File | 597 B | 0644 |
|
uda1380.h | File | 481 B | 0644 |
|
util_mem.h | File | 2.26 KB | 0644 |
|
vx_core.h | File | 15.34 KB | 0644 |
|
wavefront.h | File | 18.76 KB | 0644 |
|
wm0010.h | File | 679 B | 0644 |
|
wm1250-ev1.h | File | 656 B | 0644 |
|
wm2000.h | File | 625 B | 0644 |
|
wm2200.h | File | 1.46 KB | 0644 |
|
wm5100.h | File | 1.25 KB | 0644 |
|
wm8903.h | File | 15.16 KB | 0644 |
|
wm8904.h | File | 7.43 KB | 0644 |
|
wm8955.h | File | 662 B | 0644 |
|
wm8960.h | File | 603 B | 0644 |
|
wm8962.h | File | 1.8 KB | 0644 |
|
wm8993.h | File | 1.19 KB | 0644 |
|
wm8996.h | File | 1.4 KB | 0644 |
|
wm9081.h | File | 661 B | 0644 |
|
wm9090.h | File | 780 B | 0644 |
|
wss.h | File | 8.44 KB | 0644 |
|