+0.0.9 -> 0.1.0
+
+* big API changes
+ - added switches interfaces
+* added RawMIDI API
+
0.0.8 -> 0.0.9
* Makefile and configure.in changes
@echo
include/soundlib.h: include/header.h include/version.h include/error.h include/footer.h \
- include/control.h include/mixer.h include/pcm.h
+ include/control.h include/mixer.h include/pcm.h include/rawmidi.h
cat include/header.h include/version.h include/error.h \
include/control.h include/mixer.h \
- include/pcm.h \
+ include/pcm.h include/rawmidi.h \
include/footer.h > include/soundlib.h
install: all
cvsclean: clean
rm -f configure config.cache config.log config.status Makefile.conf \
- utils/alsa-lib.spec
+ utils/alsa-lib.spec include/config.h include/soundlib.h
pack: cvsclean
chown -R root.root ../alsa-lib
#include <linux/sound.h>
void main(void)
{
-#ifndef SND_PROTOCOL_VERSION
+#if !defined( SND_PROTOCOL_VERSION ) || !defined( SND_PROTOCOL_UNCOMPATIBLE )
exit(1);
#else
exit(0);
}
],
AC_MSG_RESULT("present"),
- AC_MSG_RESULT("not found"); echo "Fatal error: Install alsa-driver package at first..."; exit 1;,
+ AC_MSG_RESULT("not found"); echo "Fatal error: Install alsa-driver v0.2.0pre6+ package at first..."; exit 1;,
AC_MSG_RESULT("not supported"); echo "Fatal error: Cross-compiling isn't supported..."; exit 1;,
)
int snd_ctl_close( void *handle );
int snd_ctl_file_descriptor( void *handle );
int snd_ctl_hw_info( void *handle, struct snd_ctl_hw_info *info );
+int snd_ctl_switches( void *handle );
+int snd_ctl_switch( void *handle, const char *channel_id );
+int snd_ctl_switch_read( void *handle, int switchn, struct snd_ctl_switch *data );
+int snd_ctl_switch_write( void *handle, int switchn, struct snd_ctl_switch *data );
int snd_ctl_pcm_info( void *handle, int dev, snd_pcm_info_t *info );
int snd_ctl_pcm_playback_info( void *handle, int dev, snd_pcm_playback_info_t *info );
int snd_ctl_pcm_record_info( void *handle, int dev, snd_pcm_record_info_t *info );
int snd_pcm_info( void *handle, snd_pcm_info_t *info );
int snd_pcm_playback_info( void *handle, snd_pcm_playback_info_t *info );
int snd_pcm_record_info( void *handle, snd_pcm_record_info_t *info );
+int snd_pcm_switches( void *handle );
+int snd_pcm_switch( void *handle, const char *switch_id );
+int snd_pcm_switch_read( void *handle, int switchn, snd_pcm_switch_t *data );
+int snd_pcm_switch_write( void *handle, int switchn, snd_pcm_switch_t *data );
int snd_pcm_playback_format( void *handle, snd_pcm_format_t *format );
int snd_pcm_record_format( void *handle, snd_pcm_format_t *format );
int snd_pcm_playback_params( void *handle, snd_pcm_playback_params_t *params );
*/
#define SOUNDLIB_VERSION_MAJOR 0
-#define SOUNDLIB_VERSION_MINOR 0
-#define SOUNDLIB_VERSION_SUBMINOR 10
+#define SOUNDLIB_VERSION_MINOR 1
+#define SOUNDLIB_VERSION_SUBMINOR 0
#define SOUNDLIB_VERSION ( ( LIBULTRA_VERSION_MAJOR << 16 ) | ( LIBULTRA_VERSION_MINOR << 8 ) | LIB_ULTRA_VERSION_SUBMINOR )
STATIC_LIBS= control/libcontrol.a \
mixer/libmixer.a \
- pcm/libpcm.a
+ pcm/libpcm.a \
+ rawmidi/librawmidi.a
DYNAMIC_LIBS= control/libcontrol.Sa \
mixer/libmixer.Sa \
- pcm/libpcm.Sa
+ pcm/libpcm.Sa \
+ rawmidi/librawmidi.Sa
OBJECTS=error.o
SOBJECTS=error.So
pcm/libpcm.sa:
$(MAKE) -C pcm
+rawmidi/librawmidi.a:
+ $(MAKE) -C rawmidi
+rawmidi/librawmidi.sa:
+ $(MAKE) -C rawmidi
+
clean:
$(MAKE) -C control clean
$(MAKE) -C pcm clean
$(MAKE) -C mixer clean
+ $(MAKE) -C rawmidi clean
rm -f core .depend *.o *.So *.orig *~
rm -f ../lib/libsound.*
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
+#include <string.h>
#include <errno.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#include "soundlib.h"
-#define SND_FILE_CONTROL "/dev/sndcontrol%i"
+#define SND_FILE_CONTROL "/dev/snd/control%i"
#define SND_CTL_VERSION_MAX SND_PROTOCOL_VERSION( 1, 0, 0 )
typedef struct {
return 0;
}
+int snd_ctl_switches( void *handle )
+{
+ snd_ctl_t *ctl;
+ int result;
+
+ ctl = (snd_ctl_t *)handle;
+ if ( !ctl ) return -EINVAL;
+ if ( ioctl( ctl -> fd, SND_CTL_IOCTL_SWITCHES, &result ) < 0 )
+ return -errno;
+ return result;
+}
+
+int snd_ctl_switch( void *handle, const char *switch_id )
+{
+ snd_ctl_t *ctl;
+ struct snd_ctl_switch uswitch;
+ int idx, switches, err;
+
+ ctl = (snd_ctl_t *)handle;
+ if ( !ctl ) return -EINVAL;
+ /* bellow implementation isn't optimized for speed */
+ /* info about switches should be cached in the snd_mixer_t structure */
+ if ( (switches = snd_ctl_switches( handle )) < 0 )
+ return switches;
+ for ( idx = 0; idx < switches; idx++ ) {
+ if ( (err = snd_ctl_switch_read( handle, idx, &uswitch )) < 0 )
+ return err;
+ if ( !strncmp( switch_id, uswitch.name, sizeof( uswitch.name ) ) )
+ return idx;
+ }
+ return -EINVAL;
+}
+
+int snd_ctl_switch_read( void *handle, int switchn, struct snd_ctl_switch *data )
+{
+ snd_ctl_t *ctl;
+
+ ctl = (snd_ctl_t *)handle;
+ if ( !ctl ) return -EINVAL;
+ data -> switchn = switchn;
+ if ( ioctl( ctl -> fd, SND_CTL_IOCTL_SWITCH_READ, data ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_ctl_switch_write( void *handle, int switchn, struct snd_ctl_switch *data )
+{
+ snd_ctl_t *ctl;
+
+ ctl = (snd_ctl_t *)handle;
+ if ( !ctl ) return -EINVAL;
+ data -> switchn = switchn;
+ if ( ioctl( ctl -> fd, SND_CTL_IOCTL_SWITCH_WRITE, data ) < 0 )
+ return -errno;
+ return 0;
+}
+
int snd_ctl_pcm_info( void *handle, int dev, snd_pcm_info_t *info )
{
snd_ctl_t *ctl;
#include <sys/ioctl.h>
#include "soundlib.h"
-#define SND_FILE_MIXER "/dev/sndmixer%i%i"
+#define SND_FILE_MIXER "/dev/snd/mixer%i%i"
#define SND_MIXER_VERSION_MAX SND_PROTOCOL_VERSION( 1, 0, 1 )
typedef struct {
/*
* PCM Interface - main file
* Copyright (c) 1998 by Jaroslav Kysela <perex@jcu.cz>
+ *
+ *
+ * This library is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU Library General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * 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 Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ *
*/
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
+#include <string.h>
#include <errno.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#include "soundlib.h"
-#define SND_FILE_PCM "/dev/sndpcm%i%i"
+#define SND_FILE_PCM "/dev/snd/pcm%i%i"
#define SND_PCM_VERSION_MAX SND_PROTOCOL_VERSION( 1, 0, 0 )
typedef struct {
return 0;
}
+int snd_pcm_switches( void *handle )
+{
+ snd_pcm_t *pcm;
+ int result;
+
+ pcm = (snd_pcm_t *)handle;
+ if ( !pcm ) return -EINVAL;
+ if ( ioctl( pcm -> fd, SND_PCM_IOCTL_SWITCHES, &result ) < 0 )
+ return -errno;
+ return result;
+}
+
+int snd_pcm_switch( void *handle, const char *switch_id )
+{
+ snd_pcm_t *pcm;
+ snd_pcm_switch_t uswitch;
+ int idx, switches, err;
+
+ pcm = (snd_pcm_t *)handle;
+ if ( !pcm ) return -EINVAL;
+ /* bellow implementation isn't optimized for speed */
+ /* info about switches should be cached in the snd_mixer_t structure */
+ if ( (switches = snd_mixer_switches( handle )) < 0 )
+ return switches;
+ for ( idx = 0; idx < switches; idx++ ) {
+ if ( (err = snd_pcm_switch_read( handle, idx, &uswitch )) < 0 )
+ return err;
+ if ( !strncmp( switch_id, uswitch.name, sizeof( uswitch.name ) ) )
+ return idx;
+ }
+ return -EINVAL;
+}
+
+int snd_pcm_switch_read( void *handle, int switchn, snd_pcm_switch_t *data )
+{
+ snd_pcm_t *pcm;
+
+ pcm = (snd_pcm_t *)handle;
+ if ( !pcm ) return -EINVAL;
+ data -> switchn = switchn;
+ if ( ioctl( pcm -> fd, SND_PCM_IOCTL_SWITCH_READ, data ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_pcm_switch_write( void *handle, int switchn, snd_pcm_switch_t *data )
+{
+ snd_pcm_t *pcm;
+
+ pcm = (snd_pcm_t *)handle;
+ if ( !pcm ) return -EINVAL;
+ data -> switchn = switchn;
+ if ( ioctl( pcm -> fd, SND_PCM_IOCTL_SWITCH_WRITE, data ) < 0 )
+ return -errno;
+ return 0;
+}
+
int snd_pcm_playback_format( void *handle, snd_pcm_format_t *format )
{
snd_pcm_t *pcm;
--- /dev/null
+#
+# Makefile for ALSA library
+# Copyright (c) 1994-98 by Jaroslav Kysela <perex@jcu.cz>
+#
+
+include ../../Makefile.conf
+
+TARGET=librawmidi.a
+STARGET=librawmidi.Sa
+OBJECTS=rawmidi.o
+SOBJECTS=rawmidi.So
+TARGETS=$(TARGET) $(STARGET)
+
+.SUFFIXES: .c .s .S .o .So .a .Sa
+
+.c.o:
+ $(CC) $(COPTS) $(INCLUDE) -c -o $*.o $<
+.c.So:
+ $(CC) $(COPTS) $(INCLUDE) -fPIC -c -o $*.So $<
+
+all: $(TARGETS)
+
+$(TARGET): .depend $(OBJECTS)
+ $(LINKER) -r -o $@ $(OBJECTS)
+
+$(STARGET): .depend $(SOBJECTS)
+ $(LINKER) -r -o $@ $(SOBJECTS)
+
+clean:
+ rm -f core .depend *.o *.So *.a *.Sa *.orig *~
+
+.depend:
+ $(CPP) $(COPTS) $(INCLUDE) -M *.c > .depend
+
+#
+# include a dependency file if one exists
+#
+ifeq (.depend,$(wildcard .depend))
+include .depend
+endif
--- /dev/null
+/*
+ * RawMIDI Interface - main file
+ * Copyright (c) 1998 by Jaroslav Kysela <perex@jcu.cz>
+ *
+ *
+ * This library is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU Library General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * 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 Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ *
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <string.h>
+#include <errno.h>
+#include <fcntl.h>
+#include <sys/ioctl.h>
+#include "soundlib.h"
+
+#define SND_FILE_RAWMIDI "/dev/snd/rawmidi%i%i"
+#define SND_PCM_VERSION_MAX SND_PROTOCOL_VERSION( 1, 0, 0 )
+
+typedef struct {
+ int card;
+ int device;
+ int fd;
+} snd_rawmidi_t;
+
+int snd_rawmidi_open( void **handle, int card, int device, int mode )
+{
+ int fd, ver;
+ char filename[32];
+ snd_rawmidi_t *rmidi;
+
+ *handle = NULL;
+ if ( card < 0 || card >= SND_CARDS ) return -EINVAL;
+ sprintf( filename, SND_FILE_RAWMIDI, card, device );
+ if ( (fd = open( filename, mode )) < 0 ) return -errno;
+ if ( ioctl( fd, SND_PCM_IOCTL_PVERSION, &ver ) < 0 ) {
+ close( fd );
+ return -errno;
+ }
+ if ( SND_PROTOCOL_UNCOMPATIBLE( ver, SND_PCM_VERSION_MAX ) )
+ return -SND_ERROR_UNCOMPATIBLE_VERSION;
+ rmidi = (snd_rawmidi_t *)calloc( 1, sizeof( snd_rawmidi_t ) );
+ if ( rmidi == NULL ) {
+ close( fd );
+ return -ENOMEM;
+ }
+ rmidi -> card = card;
+ rmidi -> device = device;
+ rmidi -> fd = fd;
+ *handle = rmidi;
+ return 0;
+}
+
+int snd_rawmidi_close( void *handle )
+{
+ snd_rawmidi_t *rmidi;
+ int res;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ res = close( rmidi -> fd ) < 0 ? -errno : 0;
+ free( rmidi );
+ return res;
+}
+
+int snd_rawmidi_file_descriptor( void *handle )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ return rmidi -> fd;
+}
+
+int snd_rawmidi_block_mode( void *handle, int enable )
+{
+ snd_rawmidi_t *rmidi;
+ long flags;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ if ( fcntl( rmidi -> fd, F_GETFL, &flags ) < 0 )
+ return -errno;
+ if ( enable )
+ flags |= O_NONBLOCK;
+ else
+ flags &= ~O_NONBLOCK;
+ if ( fcntl( rmidi -> fd, F_SETFL, &flags ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_rawmidi_info( void *handle, snd_rawmidi_info_t *info )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_INFO, info ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_rawmidi_switches( void *handle )
+{
+ snd_rawmidi_t *rmidi;
+ int result;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_SWITCHES, &result ) < 0 )
+ return -errno;
+ return result;
+}
+
+int snd_rawmidi_switch( void *handle, const char *switch_id )
+{
+ snd_rawmidi_t *rmidi;
+ snd_rawmidi_switch_t uswitch;
+ int idx, switches, err;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ /* bellow implementation isn't optimized for speed */
+ /* info about switches should be cached in the snd_mixer_t structure */
+ if ( (switches = snd_rawmidi_switches( handle )) < 0 )
+ return switches;
+ for ( idx = 0; idx < switches; idx++ ) {
+ if ( (err = snd_rawmidi_switch_read( handle, idx, &uswitch )) < 0 )
+ return err;
+ if ( !strncmp( switch_id, uswitch.name, sizeof( uswitch.name ) ) )
+ return idx;
+ }
+ return -EINVAL;
+}
+
+int snd_rawmidi_switch_read( void *handle, int switchn, snd_rawmidi_switch_t *data )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ data -> switchn = switchn;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_SWITCH_READ, data ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_rawmidi_switch_write( void *handle, int switchn, snd_rawmidi_switch_t *data )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ data -> switchn = switchn;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_SWITCH_WRITE, data ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_rawmidi_output_params( void *handle, snd_rawmidi_output_params_t *params )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_OUTPUT_PARAMS, params ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_rawmidi_input_params( void *handle, snd_rawmidi_input_params_t *params )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_INPUT_PARAMS, params ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_rawmidi_output_status( void *handle, snd_rawmidi_output_status_t *status )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_OUTPUT_STATUS, status ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_rawmidi_input_status( void *handle, snd_rawmidi_input_status_t *status )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_INPUT_STATUS, status ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_rawmidi_drain_output( void *handle )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_DRAIN_OUTPUT ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_rawmidi_flush_output( void *handle )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_FLUSH_OUTPUT ) < 0 )
+ return -errno;
+ return 0;
+}
+
+int snd_rawmidi_flush_input( void *handle )
+{
+ snd_rawmidi_t *rmidi;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ if ( ioctl( rmidi -> fd, SND_RAWMIDI_IOCTL_FLUSH_INPUT ) < 0 )
+ return -errno;
+ return 0;
+}
+
+ssize_t snd_rawmidi_write( void *handle, const void *buffer, size_t size )
+{
+ snd_rawmidi_t *rmidi;
+ ssize_t result;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ result = write( rmidi -> fd, buffer, size );
+ if ( result < 0 ) return -errno;
+ return result;
+}
+
+ssize_t snd_rawmidi_read( void *handle, void *buffer, size_t size )
+{
+ snd_rawmidi_t *rmidi;
+ ssize_t result;
+
+ rmidi = (snd_rawmidi_t *)handle;
+ if ( !rmidi ) return -EINVAL;
+ result = read( rmidi -> fd, buffer, size );
+ if ( result < 0 ) return -errno;
+ return result;
+}