mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2025-10-24 09:30:26 -04:00
- ok, this should enable Bobs portaudio fixes and ALSA depending on
--enable options. This will have to be cleaned up a lot more to minimise #ifdef's a2d_() is needed for portaudio which is needed by both windows and *nix but only a small piece of start_threads.c is needed for portaudio the ALSA part is #ifdef'd out when USE_PORTAUDIO is enabled. audio_init.f90 and a2d.f90 now have #ifdef's on USE_PORTAUDIO instead of Win32. Lots to do still. git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/trunk@73 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
parent
bb05bf7662
commit
2858f3b9c9
14
Makefile.in
14
Makefile.in
@ -3,6 +3,7 @@ FC ?= @F77@
|
||||
FFLAGS = @FFLAGS@
|
||||
LDFLAGS = @LDFLAGS@
|
||||
CPPFLAGS = @CPPFLAGS@
|
||||
CFLAGS = @CFLAGS@
|
||||
#
|
||||
# WSJT specific Fortran flags
|
||||
FFLAGS += -Wall -fbounds-check
|
||||
@ -12,7 +13,7 @@ G95=@G95@
|
||||
COMPILER=@G95_LIB_PATH@
|
||||
|
||||
LDFLAGS += -L${COMPILER}
|
||||
LDFLAGS += -lpthread -lg2c
|
||||
LDFLAGS += -lg2c
|
||||
|
||||
PYTHON ?= @PYTHON@
|
||||
RM ?= @RM@
|
||||
@ -35,14 +36,19 @@ SRCS2F90 = a2d.f90 abc441.f90 astro0.f90 audio_init.f90 azdist0.f90 \
|
||||
wsjtgen.f90 runqqq.f90 fivehz.f90
|
||||
SRCS2F77 = wsjt1.f fsubs1.f fsubs.f astro.f astropak.f
|
||||
#
|
||||
# ok, so far for Windows @AUDIO@ will be jtaudio.c since it uses portaudio
|
||||
# for *nix @AUDIO@ will also be jtaudio.c for portaudio
|
||||
# ok, so far for now
|
||||
# Windows @AUDIO@ will be jtaudio.c since it uses portaudio
|
||||
# for *nix @AUDIO@ will also be jtaudio.c and start_threads.c
|
||||
# for portaudio
|
||||
# for *nix @AUDIO@ will be start_threads.c for alsa
|
||||
# for *nix @AUDIO@ will be ?? for oss
|
||||
#
|
||||
# ptt_unix.c vs. ptt.c I'll sort out later.
|
||||
# ditto for cutil.c (only used on *nix)
|
||||
# --db
|
||||
# jtaudio.c/start_threads.c mess will have to be sorted out later
|
||||
# to minimise #ifdef's
|
||||
# --db
|
||||
#
|
||||
SRCS2C = ptt_unix.c igray.c wrapkarn.c cutil.c
|
||||
SRCS2C += @AUDIO@
|
||||
@ -56,7 +62,7 @@ wsjt6: Audio.so #wsjt.spec
|
||||
# ${RM} wsjt6
|
||||
|
||||
Audio.so: $(OBJS2C)
|
||||
${PYTHON} ${F2PY_PY} -c --verbose --opt="-O -cpp -D${OS} \
|
||||
${PYTHON} ${F2PY_PY} -c --verbose --opt="-O -cpp -D${CFLAGS} \
|
||||
-fno-second-underscore" $(OBJS2C) -m Audio \
|
||||
--f77exec=${G95} --f90exec=${G95} ${CPPFLAGS} ${LDFLAGS} \
|
||||
only: $(F2PYONLY) \
|
||||
|
3
a2d.f90
3
a2d.f90
@ -1,7 +1,8 @@
|
||||
!---------------------------------------------------- a2d
|
||||
subroutine a2d(iarg)
|
||||
|
||||
#ifdef Win32
|
||||
#if 1
|
||||
!--- # ifdef USE_PORTAUDIO
|
||||
! Start the PortAudio streams for audio input and output.
|
||||
integer nchin(0:20),nchout(0:20)
|
||||
include 'gcom1.f90'
|
||||
|
@ -5,6 +5,8 @@ subroutine audio_init(ndin,ndout)
|
||||
#ifdef Win32
|
||||
use dfmt
|
||||
integer Thread1,Thread2
|
||||
#endif
|
||||
#ifdef USE_PORTAUDIO
|
||||
external a2d,decode1
|
||||
#endif
|
||||
|
||||
|
27
configure
vendored
27
configure
vendored
@ -2,7 +2,7 @@
|
||||
# Guess values for system-dependent variables and create Makefiles.
|
||||
# Generated by GNU Autoconf 2.53 for wsjt 0.9.
|
||||
#
|
||||
# $Id: configure.ac 70 2006-01-09 21:30:35Z va3db $
|
||||
# $Id: configure.ac 71 2006-01-09 21:35:25Z va3db $
|
||||
#
|
||||
# Copyright 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, 2002
|
||||
# Free Software Foundation, Inc.
|
||||
@ -924,7 +924,7 @@ Free Software Foundation, Inc.
|
||||
This configure script is free software; the Free Software Foundation
|
||||
gives unlimited permission to copy, distribute and modify it.
|
||||
|
||||
$Id: configure.ac 70 2006-01-09 21:30:35Z va3db $
|
||||
$Id: configure.ac 71 2006-01-09 21:35:25Z va3db $
|
||||
_ACEOF
|
||||
exit 0
|
||||
fi
|
||||
@ -2198,7 +2198,7 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu
|
||||
CFLAGS="$OLD_CFLAGS"
|
||||
|
||||
CPPFLAGS="-I/usr/local/include -I/usr/include/alsa ${CPPFLAGS}"
|
||||
LDFLAGS="-L/usr/local/lib ${LDFLAGS}"
|
||||
LDFLAGS="-L/usr/local/lib -lpthread ${LDFLAGS}"
|
||||
|
||||
echo "$as_me:$LINENO: checking uname -s for Cygwin, Solaris or HPUX" >&5
|
||||
echo $ECHO_N "checking uname -s for Cygwin, Solaris or HPUX... $ECHO_C" >&6
|
||||
@ -2236,15 +2236,15 @@ echo $ECHO_N "checking if $CC is Apple GCC... $ECHO_C" >&6
|
||||
echo "$as_me:$LINENO: result: $AppleGCC" >&5
|
||||
echo "${ECHO_T}$AppleGCC" >&6
|
||||
|
||||
WSJT_CFLAGS="$WSJT_CFLAGS -Wall -O0"
|
||||
CFLAGS="$CFLAGS -Wall -O0"
|
||||
fi
|
||||
|
||||
if test "$ac_cv_prog_cc_g" = yes; then
|
||||
WSJT_CFLAGS="$WSJT_CFLAGS -g"
|
||||
CFLAGS="$CFLAGS -g"
|
||||
fi
|
||||
|
||||
if test ! -z "$CFLAGS"; then
|
||||
WSJT_CFLAGS="$WSJT_CFLAGS $CFLAGS"
|
||||
CFLAGS="$CFLAGS $CFLAGS"
|
||||
fi
|
||||
|
||||
|
||||
@ -5556,11 +5556,10 @@ _ACEOF
|
||||
fi
|
||||
|
||||
|
||||
|
||||
if test "$prefix" = "NONE"; then
|
||||
|
||||
cat >>confdefs.h <<_ACEOF
|
||||
#define WSJT_PREFIX "$ac_default_prefix"
|
||||
#define PREFIX "$ac_default_prefix"
|
||||
_ACEOF
|
||||
|
||||
|
||||
@ -5570,7 +5569,7 @@ else
|
||||
prefix=`echo $prefix | sed 's/\/$//'`
|
||||
|
||||
cat >>confdefs.h <<_ACEOF
|
||||
#define WSJT_PREFIX "$prefix"
|
||||
#define PREFIX "$prefix"
|
||||
_ACEOF
|
||||
|
||||
|
||||
@ -5614,7 +5613,7 @@ _ACEOF
|
||||
|
||||
AUDIO="start_threads.c"
|
||||
|
||||
LDFLAGS="${LDFLAGS} -lpthreads -lasound"
|
||||
LDFLAGS="${LDFLAGS} -lpthread -lasound"
|
||||
fi
|
||||
|
||||
if test "$oss" = yes; then
|
||||
@ -5633,9 +5632,11 @@ cat >>confdefs.h <<\_ACEOF
|
||||
#define USE_PORTAUDIO 1
|
||||
_ACEOF
|
||||
|
||||
AUDIO="jtaudio.c"
|
||||
AUDIO="jtaudio.c start_threads.c"
|
||||
|
||||
LDFLAGS="${LDFLAGS} -lpthreads -lportaudio"
|
||||
LDFLAGS="${LDFLAGS} -lportaudio"
|
||||
CFLAGS="${CFLAGS} -DUSE_PORTAUDIO"
|
||||
CPPFLAGS="${CPPFLAGS} -DUSE_PORTAUDIO"
|
||||
fi
|
||||
|
||||
|
||||
@ -5689,6 +5690,7 @@ CPPFLAGS="${CPPFLAGS}"
|
||||
LDFLAGS="${LDFLAGS}"
|
||||
|
||||
|
||||
|
||||
cat >confcache <<\_ACEOF
|
||||
# This file is a shell script that caches the results of configure
|
||||
# tests run on this system so they can be shared between configure
|
||||
@ -6272,7 +6274,6 @@ s,@G95@,$G95,;t t
|
||||
s,@G95_LIB_PATH@,$G95_LIB_PATH,;t t
|
||||
s,@OS@,$OS,;t t
|
||||
s,@CLOBBER@,$CLOBBER,;t t
|
||||
s,@WSJT_CFLAGS@,$WSJT_CFLAGS,;t t
|
||||
s,@AUDIO@,$AUDIO,;t t
|
||||
CEOF
|
||||
|
||||
|
23
configure.ac
23
configure.ac
@ -24,7 +24,7 @@ CFLAGS="$OLD_CFLAGS"
|
||||
|
||||
dnl Lets guess at some likely places for extra libs/includes XXX -db
|
||||
CPPFLAGS="-I/usr/local/include -I/usr/include/alsa ${CPPFLAGS}"
|
||||
LDFLAGS="-L/usr/local/lib ${LDFLAGS}"
|
||||
LDFLAGS="-L/usr/local/lib -lpthread ${LDFLAGS}"
|
||||
|
||||
AC_MSG_CHECKING([uname -s for Cygwin, Solaris or HPUX])
|
||||
case `uname -s` in
|
||||
@ -52,19 +52,19 @@ if test "$ac_cv_c_compiler_gnu" = yes; then
|
||||
|
||||
AC_MSG_RESULT($AppleGCC)
|
||||
|
||||
WSJT_CFLAGS="$WSJT_CFLAGS -Wall -O0"
|
||||
CFLAGS="$CFLAGS -Wall -O0"
|
||||
fi
|
||||
|
||||
dnl If we support -g, use it!
|
||||
if test "$ac_cv_prog_cc_g" = yes; then
|
||||
WSJT_CFLAGS="$WSJT_CFLAGS -g"
|
||||
CFLAGS="$CFLAGS -g"
|
||||
fi
|
||||
|
||||
dnl jdc -- If CFLAGS is defined, best use it everywhere...
|
||||
dnl NOTE: jv says it must be added to the *END*, because things like
|
||||
dnl "gcc -O9 -O2" will result in -O2 getting preference. How stupid.
|
||||
if test ! -z "$CFLAGS"; then
|
||||
WSJT_CFLAGS="$WSJT_CFLAGS $CFLAGS"
|
||||
CFLAGS="$CFLAGS $CFLAGS"
|
||||
fi
|
||||
|
||||
|
||||
@ -177,10 +177,9 @@ if test "$assert" = no; then
|
||||
AC_DEFINE(NDEBUG, 1, [Define this to disable debugging support.])
|
||||
fi
|
||||
|
||||
AC_SUBST(WSJT_CFLAGS)
|
||||
|
||||
if test "$prefix" = "NONE"; then
|
||||
AC_DEFINE_UNQUOTED(WSJT_PREFIX, "$ac_default_prefix", [Prefix where wsjt is installed.])
|
||||
AC_DEFINE_UNQUOTED(PREFIX, "$ac_default_prefix", [Prefix where wsjt is installed.])
|
||||
|
||||
else
|
||||
|
||||
@ -188,7 +187,7 @@ dnl Don't get bitten by Cygwin's stupidity if the user specified
|
||||
dnl a custom prefix with a trailing slash
|
||||
|
||||
prefix=`echo $prefix | sed 's/\/$//'`
|
||||
AC_DEFINE_UNQUOTED(WSJT_PREFIX, "$prefix", [Prefix where wsjt is installed.])
|
||||
AC_DEFINE_UNQUOTED(PREFIX, "$prefix", [Prefix where wsjt is installed.])
|
||||
|
||||
fi
|
||||
|
||||
@ -220,7 +219,7 @@ AC_HELP_STRING([--enable-portaudio],[Force PORTAUDIO SOUND usage.]),
|
||||
if test "$alsa" = yes; then
|
||||
AC_DEFINE(USE_ALSA, 1, [Define if you want ALSA used.])
|
||||
AC_SUBST(AUDIO, "start_threads.c")
|
||||
LDFLAGS="${LDFLAGS} -lpthreads -lasound"
|
||||
LDFLAGS="${LDFLAGS} -lpthread -lasound"
|
||||
fi
|
||||
|
||||
if test "$oss" = yes; then
|
||||
@ -228,10 +227,13 @@ if test "$oss" = yes; then
|
||||
AC_SUBST(AUDIO, "jtaudio.c")
|
||||
fi
|
||||
|
||||
dnl XXX
|
||||
if test "$portaudio" = yes; then
|
||||
AC_DEFINE(USE_PORTAUDIO, 1, [Define if you want PORTAUDIO used.])
|
||||
AC_SUBST(AUDIO, "jtaudio.c")
|
||||
LDFLAGS="${LDFLAGS} -lpthreads -lportaudio"
|
||||
AC_SUBST(AUDIO, "jtaudio.c start_threads.c")
|
||||
LDFLAGS="${LDFLAGS} -lportaudio"
|
||||
CFLAGS="${CFLAGS} -DUSE_PORTAUDIO"
|
||||
CPPFLAGS="${CPPFLAGS} -DUSE_PORTAUDIO"
|
||||
fi
|
||||
|
||||
dnl set conf flags
|
||||
@ -270,6 +272,7 @@ fi
|
||||
dnl
|
||||
AC_SUBST(CPPFLAGS, "${CPPFLAGS}")
|
||||
AC_SUBST(LDFLAGS, "${LDFLAGS}")
|
||||
AC_SUBST(CFLAGS)
|
||||
|
||||
AC_OUTPUT
|
||||
|
||||
|
@ -3,21 +3,18 @@
|
||||
#include <pthread.h>
|
||||
#include "conf.h"
|
||||
|
||||
/*
|
||||
* XXX This should have been caught in the sanity tests in configure --db
|
||||
*/
|
||||
#if defined(USE_ALSA) && !defined(HAS_ASOUNDLIB_H)
|
||||
#error "You must have alsa support to use alsa"
|
||||
#endif
|
||||
|
||||
#if defined(USE_ALSA) && defined(HAS_ASOUNDLIB_H)
|
||||
#ifdef USE_ALSA
|
||||
#include <alsa/asoundlib.h>
|
||||
#endif
|
||||
|
||||
#include <inttypes.h>
|
||||
#include <time.h>
|
||||
|
||||
#if defined(USE_ALSA) && defined(HAS_ASOUNDLIB_H)
|
||||
#ifdef USE_PORTAUDIO
|
||||
extern a2d_();
|
||||
#endif
|
||||
|
||||
#ifdef USE_ALSA
|
||||
|
||||
#if 1
|
||||
#define ALSA_LOG
|
||||
@ -519,7 +516,7 @@ int start_threads_(int *ndevin, int *ndevout, short y1[], short y2[],
|
||||
int iarg1 = 1,iarg2 = 2;
|
||||
//int32_t rate=11025;
|
||||
int32_t rate=*nfsample;
|
||||
#if defined(USE_ALSA) && defined(HAS_ASOUNDLIB_H)
|
||||
#ifdef USE_ALSA
|
||||
alsa_driver_capture.app_buffer_y1 = y1;
|
||||
alsa_driver_capture.app_buffer_y2 = y2;
|
||||
alsa_driver_capture.app_buffer_offset = iwrite;
|
||||
@ -539,7 +536,7 @@ int start_threads_(int *ndevin, int *ndevout, short y1[], short y2[],
|
||||
#endif
|
||||
printf("start threads called\n");
|
||||
iret1 = pthread_create(&thread1,NULL,decode1_,&iarg1);
|
||||
#if defined(USE_ALSA) && defined(HAS_ASOUNDLIB_H)
|
||||
#ifdef USE_ALSA
|
||||
/* Open audio card. */
|
||||
ao_alsa_open(&alsa_driver_playback, &rate, SND_PCM_STREAM_PLAYBACK);
|
||||
ao_alsa_open(&alsa_driver_capture, &rate, SND_PCM_STREAM_CAPTURE);
|
||||
@ -552,8 +549,8 @@ int start_threads_(int *ndevin, int *ndevout, short y1[], short y2[],
|
||||
snd_pcm_start(alsa_driver_capture.audio_fd);
|
||||
snd_pcm_prepare(alsa_driver_playback.audio_fd);
|
||||
//snd_pcm_start(alsa_driver_playback.audio_fd);
|
||||
|
||||
#else
|
||||
/* snd_pcm_start */
|
||||
//iret2 = pthread_create(&thread2,NULL,a2d_,&iarg2);
|
||||
iret2 = pthread_create(&thread2,NULL,a2d_,&iarg2);
|
||||
#endif
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user