Fwd: gpsd support
Peter Stuge
peter at stuge.se
Tue Feb 22 14:58:57 CET 2011
Dario Lombardo wrote:
> +++ b/src/host/layer23/src/common/gps.c
..
> @@ -343,11 +344,38 @@ void osmo_gps_close(void)
> gps_bfd.fd = -1; /* -1 or 0 indicates: 'close' */
> }
>
> -#endif
> -
> void osmo_gps_init(void)
> {
> memset(&gps_bfd, 0, sizeof(gps_bfd));
> }
>
> +int osmo_gps_open(void)
> +{
> + switch (gps.gps_type) {
> +#ifdef _HAVE_GPSD
> + case GPS_TYPE_GPSD:
> + return osmo_gpsd_open();
> +#endif
> + case GPS_TYPE_SERIAL:
> + return osmo_serialgps_open();
> +
> + default:
> + return 0;
> + }
> +}
Maybe the program should accept the gpsd options also when not
compiled with support, and throw an error here? Benefit would be
better consistency.
> +++ b/src/host/layer23/src/misc/app_cell_log.c
..
> static struct l23_app_info info = {
> .copyright = "Copyright (C) 2010 Andreas Eversberg\n",
> -#ifdef _USE_GPSD
> - .getopt_string = "l:r:ng:p:",
> +#ifdef _HAVE_GPSD
> + .getopt_string = "l:r:nf:b:g:p:",
> #else
> - .getopt_string = "l:r:ng:b:",
> + .getopt_string = "l:r:nf:b:",
> #endif
This part *so* can not scale. Maybe use something like this..
.getopt_string = "l:r:nf:b" \
#ifdef _HAVE_GPSD
"g:p:" \
#endif
"",
> +++ b/src/host/layer23/src/mobile/vty_interface.c
> @@ -855,7 +855,7 @@ DEFUN(cfg_no_gps_enable, cfg_no_gps_enable_cmd, "no gps enable",
> return CMD_SUCCESS;
> }
>
> -#ifdef _USE_GPSD
> +#ifdef _HAVE_GPSD
> DEFUN(cfg_gps_host, cfg_gps_host_cmd, "gps host HOST:PORT",
..but again, maybe consider always having the options and commands be
supported, and failing in some other way than invalid option/command
without _HAVE_GPSD.
//Peter
More information about the baseband-devel
mailing list