Added switches API and rawmidi API...

This commit is contained in:
Jaroslav Kysela 1998-08-27 20:47:51 +00:00
parent df8ab35aac
commit ef615c857f
13 changed files with 481 additions and 13 deletions

View file

@ -1,3 +1,9 @@
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

View file

@ -21,10 +21,10 @@ all: include/soundlib.h
@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
@ -46,7 +46,7 @@ clean:
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

View file

@ -35,7 +35,7 @@ AC_TRY_RUN([
#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);
@ -43,7 +43,7 @@ void main(void)
}
],
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;,
)

View file

@ -17,6 +17,10 @@ int snd_ctl_open( void **handle, int card );
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 );

View file

@ -20,6 +20,10 @@ int snd_pcm_block_mode( void *handle, int enable );
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 );

View file

@ -3,7 +3,7 @@
*/
#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 )

View file

@ -13,10 +13,12 @@ TARGETS=$(TARGET) $(STARGET)
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
@ -56,10 +58,16 @@ pcm/libpcm.a:
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.*

View file

@ -22,12 +22,13 @@
#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 {
@ -94,6 +95,63 @@ int snd_ctl_hw_info( void *handle, struct snd_ctl_hw_info *info )
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;

View file

@ -28,7 +28,7 @@
#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 {

View file

@ -1,17 +1,34 @@
/*
* 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 {
@ -120,6 +137,63 @@ int snd_pcm_record_info( void *handle, snd_pcm_record_info_t *info )
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;

40
src/rawmidi/Makefile Normal file
View file

@ -0,0 +1,40 @@
#
# 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

274
src/rawmidi/rawmidi.c Normal file
View file

@ -0,0 +1,274 @@
/*
* 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;
}

View file

@ -1 +1 @@
0.0.10
0.1.0