mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-26 02:20:20 -04:00 
			
		
		
		
	- This adds run time parallel vs. serial PTT detection and use
- Also adds the ability to read a serial or paralle port name from WSJT.INI - Also removes serial vs. parallel hooks in configure git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/trunk@166 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
		
							parent
							
								
									fdf09163fe
								
							
						
					
					
						commit
						11021d4ad9
					
				
							
								
								
									
										53
									
								
								configure
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										53
									
								
								configure
									
									
									
									
										vendored
									
									
								
							| @ -2,7 +2,7 @@ | |||||||
| # Guess values for system-dependent variables and create Makefiles. | # Guess values for system-dependent variables and create Makefiles. | ||||||
| # Generated by GNU Autoconf 2.53 for wsjt 5.9.2. | # Generated by GNU Autoconf 2.53 for wsjt 5.9.2. | ||||||
| # | # | ||||||
| # $Id: configure.ac 161 2006-04-13 04:50:00Z va3db $ | # $Id: configure.ac 162 2006-04-13 15:13:25Z va3db $ | ||||||
| # | # | ||||||
| # Copyright 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, 2002 | # Copyright 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, 2002 | ||||||
| # Free Software Foundation, Inc. | # Free Software Foundation, Inc. | ||||||
| @ -840,8 +840,6 @@ Optional Features: | |||||||
|   --enable-oss            Force OSS SOUND usage. |   --enable-oss            Force OSS SOUND usage. | ||||||
|   --enable-portaudio      Force PORTAUDIO SOUND usage. |   --enable-portaudio      Force PORTAUDIO SOUND usage. | ||||||
|   --enable-jack           Force JACK usage. |   --enable-jack           Force JACK usage. | ||||||
|   --enable-parallel       Force PARALLEL port usage for ptt. |  | ||||||
|   --enable-serial         Force SERIAL port usage for ptt. |  | ||||||
|   --enable-g95            Use G95 compiler if available. |   --enable-g95            Use G95 compiler if available. | ||||||
|   --enable-gfortran       Use gfortran compiler if available. |   --enable-gfortran       Use gfortran compiler if available. | ||||||
| 
 | 
 | ||||||
| @ -929,7 +927,7 @@ Free Software Foundation, Inc. | |||||||
| This configure script is free software; the Free Software Foundation | This configure script is free software; the Free Software Foundation | ||||||
| gives unlimited permission to copy, distribute and modify it. | gives unlimited permission to copy, distribute and modify it. | ||||||
| 
 | 
 | ||||||
| $Id: configure.ac 161 2006-04-13 04:50:00Z va3db $ | $Id: configure.ac 162 2006-04-13 15:13:25Z va3db $ | ||||||
| _ACEOF | _ACEOF | ||||||
|   exit 0 |   exit 0 | ||||||
| fi | fi | ||||||
| @ -2076,7 +2074,7 @@ fi | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| # Provide some information about the compiler. | # Provide some information about the compiler. | ||||||
| echo "$as_me:2079:" \ | echo "$as_me:2077:" \ | ||||||
|      "checking for Fortran 77 compiler version" >&5 |      "checking for Fortran 77 compiler version" >&5 | ||||||
| ac_compiler=`set X $ac_compile; echo $2` | ac_compiler=`set X $ac_compile; echo $2` | ||||||
| { (eval echo "$as_me:$LINENO: \"$ac_compiler --version </dev/null >&5\"") >&5 | { (eval echo "$as_me:$LINENO: \"$ac_compiler --version </dev/null >&5\"") >&5 | ||||||
| @ -5977,23 +5975,6 @@ else | |||||||
| fi; | fi; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| # Check whether --enable-parallel or --disable-parallel was given. |  | ||||||
| if test "${enable_parallel+set}" = set; then |  | ||||||
|   enableval="$enable_parallel" |  | ||||||
|   parallel=$enableval |  | ||||||
| else |  | ||||||
|   parallel=no |  | ||||||
| fi; |  | ||||||
| 
 |  | ||||||
| # Check whether --enable-serial or --disable-serial was given. |  | ||||||
| if test "${enable_serial+set}" = set; then |  | ||||||
|   enableval="$enable_serial" |  | ||||||
|   serial=$enableval |  | ||||||
| else |  | ||||||
|   serial=no |  | ||||||
| fi; |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| # Check whether --enable-g95 or --disable-g95 was given. | # Check whether --enable-g95 or --disable-g95 was given. | ||||||
| if test "${enable_g95+set}" = set; then | if test "${enable_g95+set}" = set; then | ||||||
|   enableval="$enable_g95" |   enableval="$enable_g95" | ||||||
| @ -6056,26 +6037,6 @@ FC="${FC}" | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| if test "$serial" != yes -a "$parallel" != yes; then |  | ||||||
| 	serial=yes; |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if test "$serial" = yes; then |  | ||||||
| 
 |  | ||||||
| cat >>confdefs.h <<\_ACEOF |  | ||||||
| #define USE_SERIAL 1 |  | ||||||
| _ACEOF |  | ||||||
| 
 |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if test "$parallel" = yes; then |  | ||||||
| 
 |  | ||||||
| cat >>confdefs.h <<\_ACEOF |  | ||||||
| #define USE_PARALLEL 1 |  | ||||||
| _ACEOF |  | ||||||
| 
 |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if test "$alsa" != yes -a "$oss" != yes -a "$portaudio" != yes; then | if test "$alsa" != yes -a "$oss" != yes -a "$portaudio" != yes; then | ||||||
|         if test $HAS_PORTAUDIO_H -eq 1; then |         if test $HAS_PORTAUDIO_H -eq 1; then | ||||||
| 		portaudio=yes; | 		portaudio=yes; | ||||||
| @ -7079,14 +7040,6 @@ if test $jack == "yes"; then | |||||||
| 	echo "Using jack."; | 	echo "Using jack."; | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| if test $serial == "yes"; then |  | ||||||
| 	echo "Using serial port for ptt."; |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if test $parallel == "yes"; then |  | ||||||
| 	echo "Using parallel port for ptt."; |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| echo | echo | ||||||
| echo "Compiling $PACKAGE_NAME $PACKAGE_VERSION" | echo "Compiling $PACKAGE_NAME $PACKAGE_VERSION" | ||||||
| echo | echo | ||||||
|  | |||||||
							
								
								
									
										31
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								configure.ac
									
									
									
									
									
								
							| @ -234,17 +234,6 @@ AC_ARG_ENABLE(jack, | |||||||
| AC_HELP_STRING([--enable-jack],[Force JACK usage.]), | AC_HELP_STRING([--enable-jack],[Force JACK usage.]), | ||||||
| [jack=$enableval] , [jack=no]) | [jack=$enableval] , [jack=no]) | ||||||
| 
 | 
 | ||||||
| dnl serial or parallel support (temporary until python changes) |  | ||||||
| dnl =========================================================== |  | ||||||
| 
 |  | ||||||
| AC_ARG_ENABLE(parallel, |  | ||||||
| AC_HELP_STRING([--enable-parallel],[Force PARALLEL port usage for ptt.]), |  | ||||||
| [parallel=$enableval], [parallel=no]) |  | ||||||
| 
 |  | ||||||
| AC_ARG_ENABLE(serial, |  | ||||||
| AC_HELP_STRING([--enable-serial],[Force SERIAL port usage for ptt.]), |  | ||||||
| [serial=$enableval], [serial=no]) |  | ||||||
| 
 |  | ||||||
| dnl pick gfortran or g95 | dnl pick gfortran or g95 | ||||||
| dnl ==================== | dnl ==================== | ||||||
| 
 | 
 | ||||||
| @ -294,18 +283,6 @@ AC_SUBST(FC, "${FC}") | |||||||
| dnl set defaults | dnl set defaults | ||||||
| dnl ============ | dnl ============ | ||||||
| 
 | 
 | ||||||
| if test "$serial" != yes -a "$parallel" != yes; then |  | ||||||
| 	[serial=yes]; |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if test "$serial" = yes; then |  | ||||||
| 	AC_DEFINE(USE_SERIAL, 1, [Define if you want Serial port used.]) |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if test "$parallel" = yes; then |  | ||||||
| 	AC_DEFINE(USE_PARALLEL, 1, [Define if you want Serial port used.]) |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if test "$alsa" != yes -a "$oss" != yes -a "$portaudio" != yes; then | if test "$alsa" != yes -a "$oss" != yes -a "$portaudio" != yes; then | ||||||
|         if test $HAS_PORTAUDIO_H -eq 1; then |         if test $HAS_PORTAUDIO_H -eq 1; then | ||||||
| 		[portaudio=yes]; | 		[portaudio=yes]; | ||||||
| @ -431,14 +408,6 @@ if test $jack == "yes"; then | |||||||
| 	echo "Using jack."; | 	echo "Using jack."; | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| if test $serial == "yes"; then |  | ||||||
| 	echo "Using serial port for ptt."; |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if test $parallel == "yes"; then |  | ||||||
| 	echo "Using parallel port for ptt."; |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| echo | echo | ||||||
| echo "Compiling $PACKAGE_NAME $PACKAGE_VERSION" | echo "Compiling $PACKAGE_NAME $PACKAGE_VERSION" | ||||||
| echo | echo | ||||||
|  | |||||||
| @ -104,11 +104,11 @@ subroutine fivehz | |||||||
| ! Switch PTT line and TxOK appropriately | ! Switch PTT line and TxOK appropriately | ||||||
|   if(lauto.eq.1) then |   if(lauto.eq.1) then | ||||||
|      if(txtime .and. iptt.eq.0 .and.          & |      if(txtime .and. iptt.eq.0 .and.          & | ||||||
|           mute.eq.0) i1=ptt(nport,1,iptt)                !Raise PTT |           mute.eq.0) i1=ptt(nport,pttport,1,iptt)                !Raise PTT | ||||||
|      if(.not.txtime .or. mute.eq.1) TxOK=0               !Lower TxOK |      if(.not.txtime .or. mute.eq.1) TxOK=0               !Lower TxOK | ||||||
|   else |   else | ||||||
|      if(mantx.eq.1 .and. iptt.eq.0 .and.      & |      if(mantx.eq.1 .and. iptt.eq.0 .and.      & | ||||||
|           mute.eq.0) i2=ptt(nport,1,iptt)                !Raise PTT |           mute.eq.0) i2=ptt(nport,pttport,1,iptt)                !Raise PTT | ||||||
|      if(mantx.eq.0 .or. mute.eq.1) TxOK=0                !Lower TxOK |      if(mantx.eq.0 .or. mute.eq.1) TxOK=0                !Lower TxOK | ||||||
|   endif |   endif | ||||||
| 
 | 
 | ||||||
| @ -130,7 +130,7 @@ subroutine fivehz | |||||||
|   if(nc0a.lt.5) nc0a=5 |   if(nc0a.lt.5) nc0a=5 | ||||||
|   if(TxOK.eq.0 .and. TxOKz.eq.1 .and. iptt.eq.1) nc0=-nc0a-1 |   if(TxOK.eq.0 .and. TxOKz.eq.1 .and. iptt.eq.1) nc0=-nc0a-1 | ||||||
|   if(nc0.le.0) nc0=nc0+1 |   if(nc0.le.0) nc0=nc0+1 | ||||||
|   if(nc0.eq.0) i3=ptt(nport,0,iptt) |   if(nc0.eq.0) i3=ptt(nport,pttport,0,iptt) | ||||||
| 
 | 
 | ||||||
|   if(iptt.eq.0 .and.TxOK.eq.0) then |   if(iptt.eq.0 .and.TxOK.eq.0) then | ||||||
|      sending="                      " |      sending="                      " | ||||||
|  | |||||||
| @ -24,7 +24,8 @@ subroutine ftn_init | |||||||
|   include 'gcom3.f90' |   include 'gcom3.f90' | ||||||
|   include 'gcom4.f90' |   include 'gcom4.f90' | ||||||
| 
 | 
 | ||||||
|   i=ptt(nport,0,iptt)                          !Clear the PTT line | !  print*,'ftn_init.F90 nport=', nport, 'pttport=', pttport | ||||||
|  |   i=ptt(nport,pttport,0,iptt)                          !Clear the PTT line | ||||||
|   addpfx='    ' |   addpfx='    ' | ||||||
| 
 | 
 | ||||||
|   do i=80,1,-1 |   do i=80,1,-1 | ||||||
|  | |||||||
| @ -110,7 +110,7 @@ mygrid=Pmw.EntryField(g1.interior(),labelpos=W,label_text='Grid Locator:', | |||||||
| idinterval=Pmw.EntryField(g1.interior(),labelpos=W,label_text='ID Interval (m):', | idinterval=Pmw.EntryField(g1.interior(),labelpos=W,label_text='ID Interval (m):', | ||||||
|         value=10,entry_textvariable=IDinterval,entry_width=12) |         value=10,entry_textvariable=IDinterval,entry_width=12) | ||||||
| comport=Pmw.EntryField(g1.interior(),labelpos=W,label_text='PTT Port:', | comport=Pmw.EntryField(g1.interior(),labelpos=W,label_text='PTT Port:', | ||||||
|         value='1',entry_textvariable=PttPort,entry_width=12) |         value='/dev/cuad0',entry_textvariable=PttPort,entry_width=12) | ||||||
| audioin=Pmw.EntryField(g1.interior(),labelpos=W,label_text='Audio In:', | audioin=Pmw.EntryField(g1.interior(),labelpos=W,label_text='Audio In:', | ||||||
|         value='0',entry_textvariable=DevinName,entry_width=12) |         value='0',entry_textvariable=DevinName,entry_width=12) | ||||||
| audioout=Pmw.EntryField(g1.interior(),labelpos=W,label_text='Audio Out:', | audioout=Pmw.EntryField(g1.interior(),labelpos=W,label_text='Audio Out:', | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								ptt.c
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								ptt.c
									
									
									
									
									
								
							| @ -1,7 +1,7 @@ | |||||||
| #include <windows.h> | #include <windows.h> | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| 
 | 
 | ||||||
| int ptt_(int *nport, int *ntx, int *iptt) | int ptt_(int *nport, char *unused, int *ntx, int *iptt) | ||||||
| { | { | ||||||
|   static HANDLE hFile; |   static HANDLE hFile; | ||||||
|   static int open=0; |   static int open=0; | ||||||
|  | |||||||
							
								
								
									
										254
									
								
								ptt_unix.c
									
									
									
									
									
								
							
							
						
						
									
										254
									
								
								ptt_unix.c
									
									
									
									
									
								
							| @ -43,80 +43,6 @@ | |||||||
| # include <fcntl.h> | # include <fcntl.h> | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #ifdef HAVE_SYS_STAT_H |  | ||||||
| # include <sys/stat.h> |  | ||||||
| #endif |  | ||||||
| #if (defined(__unix__) || defined(unix)) && !defined(USG) |  | ||||||
| # include <sys/param.h> |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| int fd;			/* Used for both serial and parallel */ |  | ||||||
| 
 |  | ||||||
| #ifdef USE_SERIAL |  | ||||||
| 
 |  | ||||||
| /* First cut, note that this only distinguishes Linux from BSDs,
 |  | ||||||
|  * it will be done better later on using configure. N.B. that OSX |  | ||||||
|  * will come up as BSD but I think this is also the right serial port |  | ||||||
|  * for OSX. -db |  | ||||||
|  */ |  | ||||||
| #if defined(BSD) |  | ||||||
| #define TTYNAME "/dev/cuad%d"	/* Use non blocking form */ |  | ||||||
| #else |  | ||||||
| #include <sys/io.h> |  | ||||||
| #define TTYNAME	"/dev/ttyUSB%d" |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| /* Not quite right for size but '%d + 1' should be plenty enough -db */ |  | ||||||
| /* As TTYNAME is a string, just at 20 chars do udevd is happier. */ |  | ||||||
| /* E.g. USB serial ports appear as /dev/ttyUSB0 */ |  | ||||||
| #define TTYNAME_SIZE	sizeof(TTYNAME)+20 |  | ||||||
| 
 |  | ||||||
| int |  | ||||||
| ptt_(int *nport, int *ntx, int *iptt) |  | ||||||
| { |  | ||||||
|   /* Fixme, nport should be a sting and not a number */ |  | ||||||
|   static int nopen=0; |  | ||||||
|   int control = TIOCM_RTS | TIOCM_DTR; |  | ||||||
| 
 |  | ||||||
|   char s[TTYNAME_SIZE];	 |  | ||||||
| 
 |  | ||||||
|   if(*nport < 0) { |  | ||||||
|     *iptt=*ntx; |  | ||||||
|     return(0); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   if(*ntx && (!nopen)) { |  | ||||||
|     snprintf(s, TTYNAME_SIZE, TTYNAME, (*nport) - 1);	/* Comport 1 == dev 0 */ |  | ||||||
|     s[TTYNAME_SIZE] = '\0'; |  | ||||||
| 
 |  | ||||||
|     /* open the device */ |  | ||||||
|     printf("Opening %s\n", s); |  | ||||||
|     if ((fd = open(s, O_RDWR | O_NDELAY)) < 0) { |  | ||||||
|       fprintf(stderr, "Can't open %s.\n", s); |  | ||||||
|       return(1); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     nopen=1; |  | ||||||
|     return(0); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   if(*ntx && nopen) { |  | ||||||
|     ioctl(fd, TIOCMBIS, &control);               // Set DTR and RTS
 |  | ||||||
|     *iptt=1; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   else { |  | ||||||
|     ioctl(fd, TIOCMBIC, &control); |  | ||||||
|     close(fd); |  | ||||||
|     *iptt=0; |  | ||||||
|     nopen=0; |  | ||||||
|   } |  | ||||||
|   return(0); |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #ifdef USE_PARALLEL |  | ||||||
| 
 |  | ||||||
| #ifdef HAVE_LINUX_PPDEV_H | #ifdef HAVE_LINUX_PPDEV_H | ||||||
| # include <linux/ppdev.h> | # include <linux/ppdev.h> | ||||||
| # include <linux/parport.h> | # include <linux/parport.h> | ||||||
| @ -124,6 +50,10 @@ ptt_(int *nport, int *ntx, int *iptt) | |||||||
| #ifdef HAVE_DEV_PPBUS_PPI_H | #ifdef HAVE_DEV_PPBUS_PPI_H | ||||||
| # include <dev/ppbus/ppi.h> | # include <dev/ppbus/ppi.h> | ||||||
| # include <dev/ppbus/ppbconf.h> | # include <dev/ppbus/ppbconf.h> | ||||||
|  | 
 | ||||||
|  | int lp_reset (int fd); | ||||||
|  | int lp_ptt (int fd, int onoff); | ||||||
|  | 
 | ||||||
| #endif | #endif | ||||||
| #ifdef HAVE_SYS_STAT_H | #ifdef HAVE_SYS_STAT_H | ||||||
| # include <sys/stat.h> | # include <sys/stat.h> | ||||||
| @ -132,6 +62,108 @@ ptt_(int *nport, int *ntx, int *iptt) | |||||||
| # include <sys/param.h> | # include <sys/param.h> | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | #ifndef BSD		/* #ifdef LINUX ? */ | ||||||
|  | #include <sys/io.h> | ||||||
|  | #endif | ||||||
|  | #include <string.h> | ||||||
|  | /* parport functions */ | ||||||
|  | 
 | ||||||
|  | int dev_is_parport(const char *fname); | ||||||
|  | int ptt_parallel(int fd, int *ntx, int *iptt); | ||||||
|  | int ptt_serial(int fd, int *ntx, int *iptt); | ||||||
|  | 
 | ||||||
|  | int fd=-1;		/* Used for both serial and parallel */ | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | char nm[MAXPATHLEN]; | ||||||
|  | 
 | ||||||
|  | /*
 | ||||||
|  |  * ptt_ | ||||||
|  |  * | ||||||
|  |  * generic unix PTT routine called from Fortran | ||||||
|  |  * | ||||||
|  |  * unused	- Unused, to satisfy old windows calling convention | ||||||
|  |  * ptt_port	- device name serial or parallel | ||||||
|  |  * ntx		- pointer to fortran command on or off | ||||||
|  |  * iptt		- pointer to fortran command status on or off | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | /* Tiny state machine */ | ||||||
|  | #define STATE_PORT_CLOSED		0 | ||||||
|  | #define STATE_PORT_OPEN_PARALLEL	1 | ||||||
|  | #define STATE_PORT_OPEN_SERIAL		2 | ||||||
|  | 
 | ||||||
|  | int | ||||||
|  | ptt_(int unused, char *ptt_port, int *ntx, int *iptt) | ||||||
|  | { | ||||||
|  |   static int state=0; | ||||||
|  |   char *p; | ||||||
|  | 
 | ||||||
|  |   switch (state) { | ||||||
|  |   case STATE_PORT_CLOSED: | ||||||
|  |     if ((p = strchr(ptt_port, ' ')) != NULL) | ||||||
|  |       *p = '\0'; | ||||||
|  |     if (p == NULL || *p == '\0') { | ||||||
|  |       *iptt = *ntx; | ||||||
|  |       return(0); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if ((fd = dev_is_parport(ptt_port)) > 0) { | ||||||
|  |       state = STATE_PORT_OPEN_PARALLEL; | ||||||
|  |       lp_reset(fd); | ||||||
|  |     } else { | ||||||
|  |       if ((fd = open(nm, O_RDWR | O_NDELAY)) < 0) { | ||||||
|  | 	fprintf(stderr, "Can't open %s.\n", nm); | ||||||
|  | 	return(1); | ||||||
|  |       } | ||||||
|  |       else | ||||||
|  | 	state = STATE_PORT_OPEN_SERIAL; | ||||||
|  |     } | ||||||
|  |     break; | ||||||
|  | 
 | ||||||
|  |   case STATE_PORT_OPEN_PARALLEL: | ||||||
|  |     ptt_parallel(fd, ntx, iptt); | ||||||
|  |     break; | ||||||
|  | 
 | ||||||
|  |   case STATE_PORT_OPEN_SERIAL: | ||||||
|  |     ptt_serial(fd, ntx, iptt); | ||||||
|  |     break; | ||||||
|  | 
 | ||||||
|  |   default: | ||||||
|  |     close(fd); | ||||||
|  |     fd = -1; | ||||||
|  |     state = STATE_PORT_CLOSED; | ||||||
|  |     break; | ||||||
|  |   } | ||||||
|  |   return(0); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /*
 | ||||||
|  |  * ptt_serial | ||||||
|  |  * | ||||||
|  |  * generic serial unix PTT routine called indirectly from Fortran | ||||||
|  |  * | ||||||
|  |  * fd		- already opened file descriptor | ||||||
|  |  * ntx		- pointer to fortran command on or off | ||||||
|  |  * iptt		- pointer to fortran command status on or off | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | int | ||||||
|  | ptt_serial(int fd, int *ntx, int *iptt) | ||||||
|  | { | ||||||
|  |   int control = TIOCM_RTS | TIOCM_DTR; | ||||||
|  | 
 | ||||||
|  |   if(*ntx) { | ||||||
|  |     ioctl(fd, TIOCMBIS, &control);               /* Set DTR and RTS */ | ||||||
|  |     *iptt = 1; | ||||||
|  |   } else { | ||||||
|  |     ioctl(fd, TIOCMBIC, &control); | ||||||
|  |     *iptt = 0; | ||||||
|  |   } | ||||||
|  |   return(0); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| /* parport functions */ | /* parport functions */ | ||||||
| 
 | 
 | ||||||
| int lp_reset (int fd); | int lp_reset (int fd); | ||||||
| @ -149,13 +181,11 @@ int lp_ptt (int fd, int onoff); | |||||||
| int | int | ||||||
| dev_is_parport(const char *fname) | dev_is_parport(const char *fname) | ||||||
| { | { | ||||||
|        char nm[MAXPATHLEN]; |  | ||||||
|        struct stat st; |        struct stat st; | ||||||
|        int fd, m; |        int fd; | ||||||
|  | 
 | ||||||
|  |        snprintf(nm, sizeof(nm), "/dev/%s", fname); | ||||||
| 
 | 
 | ||||||
|        m = snprintf(nm, sizeof(nm), "/dev/%s", fname); |  | ||||||
|        if (m >= sizeof(nm)) |  | ||||||
|                return (-1); |  | ||||||
|        if ((fd = open(nm, O_RDWR | O_NONBLOCK)) == -1) |        if ((fd = open(nm, O_RDWR | O_NONBLOCK)) == -1) | ||||||
|                return (-1); |                return (-1); | ||||||
|        if (fstat(fd, &st) == -1) |        if (fstat(fd, &st) == -1) | ||||||
| @ -175,14 +205,16 @@ out: | |||||||
| int | int | ||||||
| dev_is_parport(const char *fname) | dev_is_parport(const char *fname) | ||||||
| { | { | ||||||
|        char nm[MAXPATHLEN]; |  | ||||||
|        struct stat st; |        struct stat st; | ||||||
|        unsigned char c; |        unsigned char c; | ||||||
|        int fd, m; |        int fd; | ||||||
|  |        char *p; | ||||||
|  | 
 | ||||||
|  |        if ((p = strchr(fname, '/')) != NULL)	/* Look for /dev */ | ||||||
|  | 	 snprintf(nm, sizeof(nm), "%s", fname); | ||||||
|  |        else | ||||||
|  | 	 snprintf(nm, sizeof(nm), "/dev/%s", fname); | ||||||
| 
 | 
 | ||||||
|        m = snprintf(nm, sizeof(nm), "/dev/%s", fname); |  | ||||||
|        if (m >= sizeof(nm)) |  | ||||||
|                return (-1); |  | ||||||
|        if ((fd = open(nm, O_RDWR | O_NONBLOCK)) == -1) |        if ((fd = open(nm, O_RDWR | O_NONBLOCK)) == -1) | ||||||
|                return (-1); |                return (-1); | ||||||
|        if (fstat(fd, &st) == -1) |        if (fstat(fd, &st) == -1) | ||||||
| @ -275,7 +307,6 @@ lp_init (int fd) | |||||||
| 	{ | 	{ | ||||||
| 		fprintf(stderr, "Claiming parallel port %s", dev->desc); | 		fprintf(stderr, "Claiming parallel port %s", dev->desc); | ||||||
| 		debug ("HINT: did you unload the lp kernel module?"); | 		debug ("HINT: did you unload the lp kernel module?"); | ||||||
| 		debug ("HINT: perhaps there is another cwdaemon running?"); |  | ||||||
| 		close (fd); | 		close (fd); | ||||||
| 		exit (1); | 		exit (1); | ||||||
| 	} | 	} | ||||||
| @ -341,47 +372,26 @@ lp_ptt (int fd, int onoff) | |||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* XXX I am totally unsure of this, LPNAME should come from
 | /*
 | ||||||
|  * the WSJT.INI instead but for now this should work -- db |  * ptt_parallel | ||||||
|  |  * | ||||||
|  |  * generic parallel unix PTT routine called indirectly from Fortran | ||||||
|  |  * | ||||||
|  |  * fd		- already opened file descriptor | ||||||
|  |  * ntx		- pointer to fortran command on or off | ||||||
|  |  * iptt		- pointer to fortran command status on or off | ||||||
|  */ |  */ | ||||||
| #ifdef BSD |  | ||||||
| #define LPNAME "lpt%d" |  | ||||||
| #else |  | ||||||
| #define LPNAME "lp%d" |  | ||||||
| #endif |  | ||||||
| #define LPNAME_SIZE (sizeof(LPNAME)) |  | ||||||
| 
 | 
 | ||||||
| int | int | ||||||
| ptt_(int *nport, int *ntx, int *iptt) | ptt_parallel(int fd, int *ntx, int *iptt) | ||||||
| { | { | ||||||
|   static int nopen=0; |   if(*ntx) { | ||||||
|   int fd; |     lp_ptt(fd, 1); | ||||||
|   char s[LPNAME_SIZE];	 |     *iptt=1; | ||||||
| 
 |   }  else { | ||||||
|   if(*nport < 0) { |     lp_ptt(fd, 0); | ||||||
|     *iptt=*ntx; |     *iptt=0; | ||||||
|     return(0); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   if(*ntx && (!nopen)) { |  | ||||||
|     snprintf(s, LPNAME_SIZE, LPNAME, (*nport) - 1);	/* Comport 1 == dev 0 */ |  | ||||||
|     s[LPNAME_SIZE] = '\0'; |  | ||||||
| 
 |  | ||||||
|     if ((fd = dev_is_parport(s)) < 0) { |  | ||||||
|       fprintf(stderr, "Can't use %s.", s); |  | ||||||
|       return(1); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     if(*ntx && nopen) { |  | ||||||
|       lp_ptt(fd, 1); |  | ||||||
|       *iptt=1; |  | ||||||
|     }  else { |  | ||||||
|       lp_ptt(fd, 0); |  | ||||||
|       close(fd); |  | ||||||
|       *iptt=0; |  | ||||||
|       nopen=0; |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
|   return(0); |   return(0); | ||||||
| } | } | ||||||
| #endif | 
 | ||||||
|  | |||||||
							
								
								
									
										6
									
								
								wsjt.py
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								wsjt.py
									
									
									
									
									
								
							| @ -1518,6 +1518,10 @@ def update(): | |||||||
|     except: |     except: | ||||||
|         Audio.gcom2.nport=0 |         Audio.gcom2.nport=0 | ||||||
| 
 | 
 | ||||||
|  | #    print 'About to init Audio.gcom2.PttPort in save some parameters' | ||||||
|  |     Audio.gcom2.pttport=(options.PttPort.get() + '            ')[:12] | ||||||
|  | #    print Audio.gcom2.pttport | ||||||
|  |      | ||||||
| # Queue up the next update | # Queue up the next update | ||||||
|     ldate.after(100,update) |     ldate.after(100,update) | ||||||
|      |      | ||||||
| @ -2022,7 +2026,7 @@ try: | |||||||
|                 options.ComPort.set(0) |                 options.ComPort.set(0) | ||||||
|                 Audio.gcom2.nport=0 |                 Audio.gcom2.nport=0 | ||||||
| 
 | 
 | ||||||
|             Audio.gcom2.PttPort=options.ComPort.get() |                 Audio.gcom2.pttport=(options.PttPort.get()+'            ')[:12] | ||||||
|      |      | ||||||
|         elif key == 'Mileskm': options.mileskm.set(value) |         elif key == 'Mileskm': options.mileskm.set(value) | ||||||
|         elif key == 'MsgStyle': options.ireport.set(value) |         elif key == 'MsgStyle': options.ireport.set(value) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user