mirror of
https://github.com/alsa-project/alsa-lib.git
synced 2025-10-31 22:25:35 -04:00
Added description of shm, null and rate plugins
This commit is contained in:
parent
f14063a251
commit
2cc79806a2
6 changed files with 216 additions and 13 deletions
|
|
@ -38,6 +38,8 @@ INPUT = index.doxygen \
|
||||||
../src/pcm/pcm_mmap.c \
|
../src/pcm/pcm_mmap.c \
|
||||||
../src/pcm/pcm_plugin.c \
|
../src/pcm/pcm_plugin.c \
|
||||||
../src/pcm/pcm_hw.c \
|
../src/pcm/pcm_hw.c \
|
||||||
|
../src/pcm/pcm_shm.c \
|
||||||
|
../src/pcm/pcm_null.c \
|
||||||
../src/pcm/pcm_copy.c \
|
../src/pcm/pcm_copy.c \
|
||||||
../src/pcm/pcm_linear.c \
|
../src/pcm/pcm_linear.c \
|
||||||
../src/pcm/pcm_lfloat.c \
|
../src/pcm/pcm_lfloat.c \
|
||||||
|
|
@ -45,6 +47,7 @@ INPUT = index.doxygen \
|
||||||
../src/pcm/pcm_alaw.c \
|
../src/pcm/pcm_alaw.c \
|
||||||
../src/pcm/pcm_adpcm.c \
|
../src/pcm/pcm_adpcm.c \
|
||||||
../src/pcm/pcm_route.c \
|
../src/pcm/pcm_route.c \
|
||||||
|
../src/pcm/pcm_rate.c \
|
||||||
../src/pcm/pcm_plug.c \
|
../src/pcm/pcm_plug.c \
|
||||||
../src/pcm/pcm_file.c \
|
../src/pcm/pcm_file.c \
|
||||||
../src/pcm/pcm_multi.c \
|
../src/pcm/pcm_multi.c \
|
||||||
|
|
|
||||||
|
|
@ -827,7 +827,7 @@ int snd_pcm_hw_open(snd_pcm_t **pcmp, const char *name,
|
||||||
|
|
||||||
This plugin communicates directly with the ALSA kernel driver. It is a raw
|
This plugin communicates directly with the ALSA kernel driver. It is a raw
|
||||||
communication without any conversions. The emulation of mmap access can be
|
communication without any conversions. The emulation of mmap access can be
|
||||||
optionally enabled, but expect a worse latency in the case.
|
optionally enabled, but expect worse latency in the case.
|
||||||
|
|
||||||
\code
|
\code
|
||||||
pcm.name {
|
pcm.name {
|
||||||
|
|
|
||||||
|
|
@ -1185,6 +1185,11 @@ This plugin allows to apply a set of LADPSA plugins.
|
||||||
The input and output format is always #SND_PCM_FORMAT_FLOAT (note: this type
|
The input and output format is always #SND_PCM_FORMAT_FLOAT (note: this type
|
||||||
can be either little or big-endian depending on architecture).
|
can be either little or big-endian depending on architecture).
|
||||||
|
|
||||||
|
The policy duplicate means that there must be only one binding definition for
|
||||||
|
channel zero. This definition is automatically duplicated for all channels.
|
||||||
|
|
||||||
|
Instances of LADSPA plugins are created dynamically.
|
||||||
|
|
||||||
\code
|
\code
|
||||||
pcm.name {
|
pcm.name {
|
||||||
type ladspa # ALSA<->LADSPA PCM
|
type ladspa # ALSA<->LADSPA PCM
|
||||||
|
|
@ -1195,15 +1200,15 @@ pcm.name {
|
||||||
# or
|
# or
|
||||||
pcm { } # Slave PCM definition
|
pcm { } # Slave PCM definition
|
||||||
}
|
}
|
||||||
path STR # Path (directory) with LADSPA plugins
|
[path STR] # Path (directory) with LADSPA plugins
|
||||||
plugins | # Definition for both directions
|
plugins | # Definition for both directions
|
||||||
playback_plugins | # Definition for playback direction
|
playback_plugins | # Definition for playback direction
|
||||||
capture_plugins { # Definition for capture direction
|
capture_plugins { # Definition for capture direction
|
||||||
N { # Configuration for LADPSA plugin N
|
N { # Configuration for LADPSA plugin N
|
||||||
id INT # LADSPA plugin ID (for example 1043)
|
[id INT] # LADSPA plugin ID (for example 1043)
|
||||||
label STR # LADSPA plugin label (for example 'delay_5s')
|
[label STR] # LADSPA plugin label (for example 'delay_5s')
|
||||||
filename STR # Full filename of .so library with LADSPA plugin code
|
[filename STR] # Full filename of .so library with LADSPA plugin code
|
||||||
policy STR # Policy can be 'none' or 'duplicate'
|
[policy STR] # Policy can be 'none' or 'duplicate'
|
||||||
input | output {
|
input | output {
|
||||||
bindings {
|
bindings {
|
||||||
C INT or STR # C - channel, INT - audio port index, STR - audio port name
|
C INT or STR # C - channel, INT - audio port index, STR - audio port name
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,10 @@
|
||||||
|
/**
|
||||||
|
* \file pcm/pcm_null.c
|
||||||
|
* \ingroup PCM_Plugins
|
||||||
|
* \brief PCM Null Plugin Interface
|
||||||
|
* \author Abramo Bagnara <abramo@alsa-project.org>
|
||||||
|
* \date 2000-2001
|
||||||
|
*/
|
||||||
/*
|
/*
|
||||||
* PCM - Null plugin
|
* PCM - Null plugin
|
||||||
* Copyright (c) 2000 by Abramo Bagnara <abramo@alsa-project.org>
|
* Copyright (c) 2000 by Abramo Bagnara <abramo@alsa-project.org>
|
||||||
|
|
@ -30,6 +37,7 @@
|
||||||
const char *_snd_module_pcm_null = "";
|
const char *_snd_module_pcm_null = "";
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef DOC_HIDDEN
|
||||||
typedef struct {
|
typedef struct {
|
||||||
snd_timestamp_t trigger_tstamp;
|
snd_timestamp_t trigger_tstamp;
|
||||||
snd_pcm_state_t state;
|
snd_pcm_state_t state;
|
||||||
|
|
@ -38,6 +46,7 @@ typedef struct {
|
||||||
snd_pcm_uframes_t hw_ptr;
|
snd_pcm_uframes_t hw_ptr;
|
||||||
int poll_fd;
|
int poll_fd;
|
||||||
} snd_pcm_null_t;
|
} snd_pcm_null_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
static int snd_pcm_null_close(snd_pcm_t *pcm)
|
static int snd_pcm_null_close(snd_pcm_t *pcm)
|
||||||
{
|
{
|
||||||
|
|
@ -295,7 +304,7 @@ static void snd_pcm_null_dump(snd_pcm_t *pcm, snd_output_t *out)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
snd_pcm_ops_t snd_pcm_null_ops = {
|
static snd_pcm_ops_t snd_pcm_null_ops = {
|
||||||
close: snd_pcm_null_close,
|
close: snd_pcm_null_close,
|
||||||
info: snd_pcm_null_info,
|
info: snd_pcm_null_info,
|
||||||
hw_refine: snd_pcm_null_hw_refine,
|
hw_refine: snd_pcm_null_hw_refine,
|
||||||
|
|
@ -310,7 +319,7 @@ snd_pcm_ops_t snd_pcm_null_ops = {
|
||||||
munmap: snd_pcm_null_munmap,
|
munmap: snd_pcm_null_munmap,
|
||||||
};
|
};
|
||||||
|
|
||||||
snd_pcm_fast_ops_t snd_pcm_null_fast_ops = {
|
static snd_pcm_fast_ops_t snd_pcm_null_fast_ops = {
|
||||||
status: snd_pcm_null_status,
|
status: snd_pcm_null_status,
|
||||||
state: snd_pcm_null_state,
|
state: snd_pcm_null_state,
|
||||||
delay: snd_pcm_null_delay,
|
delay: snd_pcm_null_delay,
|
||||||
|
|
@ -330,6 +339,17 @@ snd_pcm_fast_ops_t snd_pcm_null_fast_ops = {
|
||||||
mmap_commit: snd_pcm_null_mmap_commit,
|
mmap_commit: snd_pcm_null_mmap_commit,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Creates a new null PCM
|
||||||
|
* \param pcmp Returns created PCM handle
|
||||||
|
* \param name Name of PCM
|
||||||
|
* \param stream Stream type
|
||||||
|
* \param mode Stream mode
|
||||||
|
* \retval zero on success otherwise a negative error code
|
||||||
|
* \warning Using of this function might be dangerous in the sense
|
||||||
|
* of compatibility reasons. The prototype might be freely
|
||||||
|
* changed in future.
|
||||||
|
*/
|
||||||
int snd_pcm_null_open(snd_pcm_t **pcmp, const char *name, snd_pcm_stream_t stream, int mode)
|
int snd_pcm_null_open(snd_pcm_t **pcmp, const char *name, snd_pcm_stream_t stream, int mode)
|
||||||
{
|
{
|
||||||
snd_pcm_t *pcm;
|
snd_pcm_t *pcm;
|
||||||
|
|
@ -375,6 +395,44 @@ int snd_pcm_null_open(snd_pcm_t **pcmp, const char *name, snd_pcm_stream_t strea
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*! \page pcm_plugins
|
||||||
|
|
||||||
|
\section pcm_plugins_null Plugin: Null
|
||||||
|
|
||||||
|
This plugin discards contents of a PCM stream or creates a stream with zero
|
||||||
|
samples.
|
||||||
|
|
||||||
|
Note: This implementation uses devices /dev/null (playback, must be writeable)
|
||||||
|
and /dev/full (capture, must be readable).
|
||||||
|
|
||||||
|
\code
|
||||||
|
pcm.name {
|
||||||
|
type null # Null PCM
|
||||||
|
}
|
||||||
|
\endcode
|
||||||
|
|
||||||
|
\subsection pcm_plugins_null_funcref Function reference
|
||||||
|
|
||||||
|
<UL>
|
||||||
|
<LI>snd_pcm_null_open()
|
||||||
|
<LI>_snd_pcm_null_open()
|
||||||
|
</UL>
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Creates a new Null PCM
|
||||||
|
* \param pcmp Returns created PCM handle
|
||||||
|
* \param name Name of PCM
|
||||||
|
* \param root Root configuration node
|
||||||
|
* \param conf Configuration node with Null PCM description
|
||||||
|
* \param stream Stream type
|
||||||
|
* \param mode Stream mode
|
||||||
|
* \retval zero on success otherwise a negative error code
|
||||||
|
* \warning Using of this function might be dangerous in the sense
|
||||||
|
* of compatibility reasons. The prototype might be freely
|
||||||
|
* changed in future.
|
||||||
|
*/
|
||||||
int _snd_pcm_null_open(snd_pcm_t **pcmp, const char *name,
|
int _snd_pcm_null_open(snd_pcm_t **pcmp, const char *name,
|
||||||
snd_config_t *conf,
|
snd_config_t *conf,
|
||||||
snd_pcm_stream_t stream, int mode)
|
snd_pcm_stream_t stream, int mode)
|
||||||
|
|
@ -392,4 +450,6 @@ int _snd_pcm_null_open(snd_pcm_t **pcmp, const char *name,
|
||||||
}
|
}
|
||||||
return snd_pcm_null_open(pcmp, name, stream, mode);
|
return snd_pcm_null_open(pcmp, name, stream, mode);
|
||||||
}
|
}
|
||||||
|
#ifndef DOC_HIDDEN
|
||||||
SND_DLSYM_BUILD_VERSION(_snd_pcm_null_open, SND_PCM_DLSYM_VERSION);
|
SND_DLSYM_BUILD_VERSION(_snd_pcm_null_open, SND_PCM_DLSYM_VERSION);
|
||||||
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,10 @@
|
||||||
|
/**
|
||||||
|
* \file pcm/pcm_rate.c
|
||||||
|
* \ingroup PCM_Plugins
|
||||||
|
* \brief PCM Rate Plugin Interface
|
||||||
|
* \author Abramo Bagnara <abramo@alsa-project.org>
|
||||||
|
* \date 2000-2001
|
||||||
|
*/
|
||||||
/*
|
/*
|
||||||
* PCM - Rate conversion
|
* PCM - Rate conversion
|
||||||
* Copyright (c) 2000 by Abramo Bagnara <abramo@alsa-project.org>
|
* Copyright (c) 2000 by Abramo Bagnara <abramo@alsa-project.org>
|
||||||
|
|
@ -29,6 +36,8 @@
|
||||||
const char *_snd_module_pcm_rate = "";
|
const char *_snd_module_pcm_rate = "";
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef DOC_HIDDEN
|
||||||
|
|
||||||
#define DIV (1<<16)
|
#define DIV (1<<16)
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
|
@ -212,6 +221,8 @@ static snd_pcm_uframes_t snd_pcm_rate_shrink(const snd_pcm_channel_area_t *dst_a
|
||||||
return src_frames1;
|
return src_frames1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif /* DOC_HIDDEN */
|
||||||
|
|
||||||
static int snd_pcm_rate_hw_refine_cprepare(snd_pcm_t *pcm ATTRIBUTE_UNUSED, snd_pcm_hw_params_t *params)
|
static int snd_pcm_rate_hw_refine_cprepare(snd_pcm_t *pcm ATTRIBUTE_UNUSED, snd_pcm_hw_params_t *params)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
@ -479,7 +490,7 @@ static void snd_pcm_rate_dump(snd_pcm_t *pcm, snd_output_t *out)
|
||||||
snd_pcm_dump(rate->plug.slave, out);
|
snd_pcm_dump(rate->plug.slave, out);
|
||||||
}
|
}
|
||||||
|
|
||||||
snd_pcm_ops_t snd_pcm_rate_ops = {
|
static snd_pcm_ops_t snd_pcm_rate_ops = {
|
||||||
close: snd_pcm_plugin_close,
|
close: snd_pcm_plugin_close,
|
||||||
info: snd_pcm_plugin_info,
|
info: snd_pcm_plugin_info,
|
||||||
hw_refine: snd_pcm_rate_hw_refine,
|
hw_refine: snd_pcm_rate_hw_refine,
|
||||||
|
|
@ -494,6 +505,20 @@ snd_pcm_ops_t snd_pcm_rate_ops = {
|
||||||
munmap: snd_pcm_plugin_munmap,
|
munmap: snd_pcm_plugin_munmap,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Creates a new rate PCM
|
||||||
|
* \param pcmp Returns created PCM handle
|
||||||
|
* \param name Name of PCM
|
||||||
|
* \param sformat Slave format
|
||||||
|
* \param srate Slave rate
|
||||||
|
* \param slave Slave PCM handle
|
||||||
|
* \param close_slave When set, the slave PCM handle is closed with copy PCM
|
||||||
|
* \retval zero on success otherwise a negative error code
|
||||||
|
* \warning Using of this function might be dangerous in the sense
|
||||||
|
* of compatibility reasons. The prototype might be freely
|
||||||
|
* changed in future.
|
||||||
|
*/
|
||||||
int snd_pcm_rate_open(snd_pcm_t **pcmp, const char *name, snd_pcm_format_t sformat, unsigned int srate, snd_pcm_t *slave, int close_slave)
|
int snd_pcm_rate_open(snd_pcm_t **pcmp, const char *name, snd_pcm_format_t sformat, unsigned int srate, snd_pcm_t *slave, int close_slave)
|
||||||
{
|
{
|
||||||
snd_pcm_t *pcm;
|
snd_pcm_t *pcm;
|
||||||
|
|
@ -533,6 +558,47 @@ int snd_pcm_rate_open(snd_pcm_t **pcmp, const char *name, snd_pcm_format_t sform
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*! \page pcm_plugins
|
||||||
|
|
||||||
|
\section pcm_plugins_rate Plugin: Rate
|
||||||
|
|
||||||
|
This plugin converts a stream rate. The input and output formats must be linear.
|
||||||
|
|
||||||
|
\code
|
||||||
|
pcm.name {
|
||||||
|
type rate # Rate PCM
|
||||||
|
slave STR # Slave name
|
||||||
|
# or
|
||||||
|
slave { # Slave definition
|
||||||
|
pcm STR # Slave PCM name
|
||||||
|
# or
|
||||||
|
pcm { } # Slave PCM definition
|
||||||
|
}
|
||||||
|
}
|
||||||
|
\endcode
|
||||||
|
|
||||||
|
\subsection pcm_plugins_rate_funcref Function reference
|
||||||
|
|
||||||
|
<UL>
|
||||||
|
<LI>snd_pcm_rate_open()
|
||||||
|
<LI>_snd_pcm_rate_open()
|
||||||
|
</UL>
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Creates a new rate PCM
|
||||||
|
* \param pcmp Returns created PCM handle
|
||||||
|
* \param name Name of PCM
|
||||||
|
* \param root Root configuration node
|
||||||
|
* \param conf Configuration node with rate PCM description
|
||||||
|
* \param stream Stream type
|
||||||
|
* \param mode Stream mode
|
||||||
|
* \retval zero on success otherwise a negative error code
|
||||||
|
* \warning Using of this function might be dangerous in the sense
|
||||||
|
* of compatibility reasons. The prototype might be freely
|
||||||
|
* changed in future.
|
||||||
|
*/
|
||||||
int _snd_pcm_rate_open(snd_pcm_t **pcmp, const char *name,
|
int _snd_pcm_rate_open(snd_pcm_t **pcmp, const char *name,
|
||||||
snd_config_t *root, snd_config_t *conf,
|
snd_config_t *root, snd_config_t *conf,
|
||||||
snd_pcm_stream_t stream, int mode)
|
snd_pcm_stream_t stream, int mode)
|
||||||
|
|
@ -582,4 +648,6 @@ int _snd_pcm_rate_open(snd_pcm_t **pcmp, const char *name,
|
||||||
snd_pcm_close(spcm);
|
snd_pcm_close(spcm);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
#ifndef DOC_HIDDEN
|
||||||
SND_DLSYM_BUILD_VERSION(_snd_pcm_rate_open, SND_PCM_DLSYM_VERSION);
|
SND_DLSYM_BUILD_VERSION(_snd_pcm_rate_open, SND_PCM_DLSYM_VERSION);
|
||||||
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,12 @@
|
||||||
|
/**
|
||||||
|
* \file pcm/pcm_shm.c
|
||||||
|
* \ingroup PCM_Plugins
|
||||||
|
* \brief PCM Shared Memory Plugin Interface
|
||||||
|
* \author Abramo Bagnara <abramo@alsa-project.org>
|
||||||
|
* \date 2000-2001
|
||||||
|
*/
|
||||||
/*
|
/*
|
||||||
* PCM - SHM Client
|
* PCM - Shared Memory Client
|
||||||
* Copyright (c) 2000 by Abramo Bagnara <abramo@alsa-project.org>
|
* Copyright (c) 2000 by Abramo Bagnara <abramo@alsa-project.org>
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
|
|
@ -43,11 +50,14 @@
|
||||||
const char *_snd_module_pcm_shm = "";
|
const char *_snd_module_pcm_shm = "";
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef DOC_HIDDEN
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int socket;
|
int socket;
|
||||||
volatile snd_pcm_shm_ctrl_t *ctrl;
|
volatile snd_pcm_shm_ctrl_t *ctrl;
|
||||||
} snd_pcm_shm_t;
|
} snd_pcm_shm_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef DOC_HIDDEN
|
||||||
int receive_fd(int sock, void *data, size_t len, int *fd)
|
int receive_fd(int sock, void *data, size_t len, int *fd)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
@ -81,6 +91,7 @@ int receive_fd(int sock, void *data, size_t len, int *fd)
|
||||||
*fd = *fds;
|
*fd = *fds;
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static int snd_pcm_shm_action(snd_pcm_t *pcm)
|
static int snd_pcm_shm_action(snd_pcm_t *pcm)
|
||||||
{
|
{
|
||||||
|
|
@ -493,7 +504,7 @@ static void snd_pcm_shm_dump(snd_pcm_t *pcm, snd_output_t *out)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
snd_pcm_ops_t snd_pcm_shm_ops = {
|
static snd_pcm_ops_t snd_pcm_shm_ops = {
|
||||||
close: snd_pcm_shm_close,
|
close: snd_pcm_shm_close,
|
||||||
info: snd_pcm_shm_info,
|
info: snd_pcm_shm_info,
|
||||||
hw_refine: snd_pcm_shm_hw_refine,
|
hw_refine: snd_pcm_shm_hw_refine,
|
||||||
|
|
@ -508,7 +519,7 @@ snd_pcm_ops_t snd_pcm_shm_ops = {
|
||||||
munmap: snd_pcm_shm_munmap,
|
munmap: snd_pcm_shm_munmap,
|
||||||
};
|
};
|
||||||
|
|
||||||
snd_pcm_fast_ops_t snd_pcm_shm_fast_ops = {
|
static snd_pcm_fast_ops_t snd_pcm_shm_fast_ops = {
|
||||||
status: snd_pcm_shm_status,
|
status: snd_pcm_shm_status,
|
||||||
state: snd_pcm_shm_state,
|
state: snd_pcm_shm_state,
|
||||||
delay: snd_pcm_shm_delay,
|
delay: snd_pcm_shm_delay,
|
||||||
|
|
@ -578,7 +589,22 @@ static int make_inet_socket(const char *host, int port)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int snd_pcm_shm_open(snd_pcm_t **pcmp, const char *name, const char *sockname, const char *sname, snd_pcm_stream_t stream, int mode)
|
/**
|
||||||
|
* \brief Creates a new shared memory PCM
|
||||||
|
* \param pcmp Returns created PCM handle
|
||||||
|
* \param name Name of PCM
|
||||||
|
* \param sockname Unix socket name
|
||||||
|
* \param sname Server name
|
||||||
|
* \param stream PCM Stream
|
||||||
|
* \param mode PCM Mode
|
||||||
|
* \retval zero on success otherwise a negative error code
|
||||||
|
* \warning Using of this function might be dangerous in the sense
|
||||||
|
* of compatibility reasons. The prototype might be freely
|
||||||
|
* changed in future.
|
||||||
|
*/
|
||||||
|
int snd_pcm_shm_open(snd_pcm_t **pcmp, const char *name,
|
||||||
|
const char *sockname, const char *sname,
|
||||||
|
snd_pcm_stream_t stream, int mode)
|
||||||
{
|
{
|
||||||
snd_pcm_t *pcm;
|
snd_pcm_t *pcm;
|
||||||
snd_pcm_shm_t *shm = NULL;
|
snd_pcm_shm_t *shm = NULL;
|
||||||
|
|
@ -679,6 +705,7 @@ int snd_pcm_shm_open(snd_pcm_t **pcmp, const char *name, const char *sockname, c
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef DOC_HIDDEN
|
||||||
int is_local(struct hostent *hent)
|
int is_local(struct hostent *hent)
|
||||||
{
|
{
|
||||||
int s;
|
int s;
|
||||||
|
|
@ -723,7 +750,45 @@ int is_local(struct hostent *hent)
|
||||||
free(conf.ifc_buf);
|
free(conf.ifc_buf);
|
||||||
return i < numreqs;
|
return i < numreqs;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*! \page pcm_plugins
|
||||||
|
|
||||||
|
\section pcm_plugins_shm Plugin: shm
|
||||||
|
|
||||||
|
This plugin communicates with aserver via shared memory. It is a raw
|
||||||
|
communication without any conversions, but it can be expected worse
|
||||||
|
performance.
|
||||||
|
|
||||||
|
\code
|
||||||
|
pcm.name {
|
||||||
|
type shm # Shared memory PCM
|
||||||
|
server STR # Server name
|
||||||
|
pcm STR # PCM name
|
||||||
|
}
|
||||||
|
\endcode
|
||||||
|
|
||||||
|
\subsection pcm_plugins_shm_funcref Function reference
|
||||||
|
|
||||||
|
<UL>
|
||||||
|
<LI>snd_pcm_shm_open()
|
||||||
|
<LI>_snd_pcm_shm_open()
|
||||||
|
</UL>
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Creates a new shm PCM
|
||||||
|
* \param pcmp Returns created PCM handle
|
||||||
|
* \param name Name of PCM
|
||||||
|
* \param root Root configuration node
|
||||||
|
* \param conf Configuration node with hw PCM description
|
||||||
|
* \param stream PCM Stream
|
||||||
|
* \param mode PCM Mode
|
||||||
|
* \warning Using of this function might be dangerous in the sense
|
||||||
|
* of compatibility reasons. The prototype might be freely
|
||||||
|
* changed in future.
|
||||||
|
*/
|
||||||
int _snd_pcm_shm_open(snd_pcm_t **pcmp, const char *name,
|
int _snd_pcm_shm_open(snd_pcm_t **pcmp, const char *name,
|
||||||
snd_config_t *root, snd_config_t *conf,
|
snd_config_t *root, snd_config_t *conf,
|
||||||
snd_pcm_stream_t stream, int mode)
|
snd_pcm_stream_t stream, int mode)
|
||||||
|
|
@ -841,4 +906,6 @@ int _snd_pcm_shm_open(snd_pcm_t **pcmp, const char *name,
|
||||||
snd_config_delete(sconfig);
|
snd_config_delete(sconfig);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
#ifndef DOC_HIDDEN
|
||||||
SND_DLSYM_BUILD_VERSION(_snd_pcm_shm_open, SND_PCM_DLSYM_VERSION);
|
SND_DLSYM_BUILD_VERSION(_snd_pcm_shm_open, SND_PCM_DLSYM_VERSION);
|
||||||
|
#endif
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue