summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--content/browser/geolocation/gps_location_provider_unittest_linux.cc7
-rw-r--r--content/browser/geolocation/libgps_2_38_wrapper_linux.cc68
-rw-r--r--content/browser/geolocation/libgps_2_94_wrapper_linux.cc7
-rw-r--r--content/browser/geolocation/libgps_wrapper_linux.cc49
-rw-r--r--content/browser/geolocation/libgps_wrapper_linux.h6
-rw-r--r--content/content_browser.gypi1
-rw-r--r--third_party/gpsd/README.chromium10
-rw-r--r--third_party/gpsd/release-2.38/gps.h651
-rwxr-xr-xtools/checklicenses/checklicenses.py3
9 files changed, 27 insertions, 775 deletions
diff --git a/content/browser/geolocation/gps_location_provider_unittest_linux.cc b/content/browser/geolocation/gps_location_provider_unittest_linux.cc
index 7d896e1..f7bbd97 100644
--- a/content/browser/geolocation/gps_location_provider_unittest_linux.cc
+++ b/content/browser/geolocation/gps_location_provider_unittest_linux.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -82,10 +82,6 @@ int gps_close_stub(gps_data_t*) {
int gps_poll_stub(gps_data_t*) {
return 0;
}
-// v2.34 only
-int gps_query_stub(gps_data_t*, const char*, ...) {
- return 0;
-}
// v2.90+
int gps_stream_stub(gps_data_t*, unsigned int, void*) {
return 0;
@@ -109,7 +105,6 @@ MockLibGps::MockLibGps()
gps_open_stub,
gps_close_stub,
gps_poll_stub,
- gps_query_stub,
gps_stream_stub,
gps_waiting_stub)),
start_streaming_calls_(0),
diff --git a/content/browser/geolocation/libgps_2_38_wrapper_linux.cc b/content/browser/geolocation/libgps_2_38_wrapper_linux.cc
deleted file mode 100644
index 7cfdb52..0000000
--- a/content/browser/geolocation/libgps_2_38_wrapper_linux.cc
+++ /dev/null
@@ -1,68 +0,0 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-// Defines a variant of libgps wrapper for use with the 2.38 release of the API.
-
-#include "content/browser/geolocation/libgps_wrapper_linux.h"
-
-// This lot needed for DataWaiting()
-#include <sys/socket.h>
-#include <sys/time.h>
-
-#include "base/logging.h"
-#include "content/common/geoposition.h"
-#include "third_party/gpsd/release-2.38/gps.h"
-
-class LibGpsV238 : public LibGps {
- public:
- explicit LibGpsV238(LibGpsLibraryWrapper* dl_wrapper) : LibGps(dl_wrapper) {}
-
- // LibGps
- virtual bool StartStreaming() {
- return library().query("w+x\n") == 0;
- }
- virtual bool DataWaiting() {
- // Unfortunately the 2.38 API has no public method for non-blocking test
- // for new data arrived, so we must contrive our own by doing a select() on
- // the underlying struct's socket fd.
- fd_set fds;
- struct timeval timeout = {0};
- int fd = library().data().gps_fd;
-
- FD_ZERO(&fds);
- FD_SET(fd, &fds);
-
- int ret = select(fd + 1, &fds, NULL, NULL, &timeout);
- if (ret == -1) {
- LOG(WARNING) << "libgps socket select failed: " << ret;
- return false;
- }
- DCHECK_EQ(!!ret, !!FD_ISSET(fd, &fds));
- return ret;
- }
- virtual bool GetPositionIfFixed(Geoposition* position) {
- // This function is duplicated between the library versions, however it
- // cannot be shared as each one must be strictly compiled against the
- // corresponding version of gps.h.
- DCHECK(position);
- const gps_data_t& gps_data = library().data();
- if (gps_data.status == STATUS_NO_FIX)
- return false;
- position->latitude = gps_data.fix.latitude;
- position->longitude = gps_data.fix.longitude;
- position->accuracy = gps_data.fix.eph;
- position->altitude = gps_data.fix.altitude;
- position->altitude_accuracy = gps_data.fix.epv;
- position->heading = gps_data.fix.track;
- position->speed = gps_data.fix.speed;
- return true;
- }
-
- private:
- DISALLOW_COPY_AND_ASSIGN(LibGpsV238);
-};
-
-LibGps* LibGps::NewV238(LibGpsLibraryWrapper* dl_wrapper) {
- return new LibGpsV238(dl_wrapper);
-}
diff --git a/content/browser/geolocation/libgps_2_94_wrapper_linux.cc b/content/browser/geolocation/libgps_2_94_wrapper_linux.cc
index c9fb1bd..093afc7 100644
--- a/content/browser/geolocation/libgps_2_94_wrapper_linux.cc
+++ b/content/browser/geolocation/libgps_2_94_wrapper_linux.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -32,6 +32,11 @@ class LibGpsV294 : public LibGps {
position->latitude = gps_data.fix.latitude;
position->longitude = gps_data.fix.longitude;
position->accuracy = std::max(gps_data.fix.epx, gps_data.fix.epy);
+ if (position->accuracy != position->accuracy) {
+ // TODO(joth): Fixme. This is a workaround for http://crbug.com/99326
+ LOG(WARNING) << "libgps reported accuracy NaN, forcing to zero";
+ position->accuracy = 0;
+ }
position->altitude = gps_data.fix.altitude;
position->altitude_accuracy = gps_data.fix.epv;
position->heading = gps_data.fix.track;
diff --git a/content/browser/geolocation/libgps_wrapper_linux.cc b/content/browser/geolocation/libgps_wrapper_linux.cc
index e1d47880..b0b2315 100644
--- a/content/browser/geolocation/libgps_wrapper_linux.cc
+++ b/content/browser/geolocation/libgps_wrapper_linux.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -12,18 +12,14 @@
#include "content/common/geoposition.h"
namespace {
-// Pass to TryToOpen() to indicate which functions should be wired up.
-// This could be turned into a bit mask if required, but for now the
-// two options are mutually exclusive.
-enum InitMode {
- INITMODE_QUERY,
- INITMODE_STREAM,
-};
-
// Attempts to load dynamic library named |lib| and initialize the required
// function pointers according to |mode|. Returns ownership a new instance
// of the library loader class, or NULL on failure.
-LibGpsLibraryWrapper* TryToOpen(const char* lib, InitMode mode) {
+// TODO(joth): This is a hang-over from when we dynamically two different
+// versions of libgps and chose between them. Now we could remove at least one
+// layer of wrapper class and directly #include gps.h in this cc file.
+// See http://crbug.com/98132 and http://crbug.com/99177
+LibGpsLibraryWrapper* TryToOpen(const char* lib) {
void* dl_handle = dlopen(lib, RTLD_LAZY);
if (!dl_handle) {
VLOG(1) << "Could not open " << lib << ": " << dlerror();
@@ -31,28 +27,26 @@ LibGpsLibraryWrapper* TryToOpen(const char* lib, InitMode mode) {
}
VLOG(1) << "Loaded " << lib;
- #define DECLARE_FN_POINTER(function, required) \
+ #define DECLARE_FN_POINTER(function) \
LibGpsLibraryWrapper::function##_fn function; \
function = reinterpret_cast<LibGpsLibraryWrapper::function##_fn>( \
dlsym(dl_handle, #function)); \
- if ((required) && !function) { \
+ if (!function) { \
LOG(WARNING) << "libgps " << #function << " error: " << dlerror(); \
dlclose(dl_handle); \
return NULL; \
}
- DECLARE_FN_POINTER(gps_open, true);
- DECLARE_FN_POINTER(gps_close, true);
- DECLARE_FN_POINTER(gps_poll, true);
- DECLARE_FN_POINTER(gps_query, mode == INITMODE_QUERY);
- DECLARE_FN_POINTER(gps_stream, mode == INITMODE_STREAM);
- DECLARE_FN_POINTER(gps_waiting, mode == INITMODE_STREAM);
+ DECLARE_FN_POINTER(gps_open);
+ DECLARE_FN_POINTER(gps_close);
+ DECLARE_FN_POINTER(gps_poll);
+ DECLARE_FN_POINTER(gps_stream);
+ DECLARE_FN_POINTER(gps_waiting);
#undef DECLARE_FN_POINTER
return new LibGpsLibraryWrapper(dl_handle,
gps_open,
gps_close,
gps_poll,
- gps_query,
gps_stream,
gps_waiting);
}
@@ -68,13 +62,10 @@ LibGps::~LibGps() {
LibGps* LibGps::New() {
LibGpsLibraryWrapper* wrapper;
- wrapper = TryToOpen("libgps.so.19", INITMODE_STREAM);
+ wrapper = TryToOpen("libgps.so.19");
if (wrapper)
return NewV294(wrapper);
- wrapper = TryToOpen("libgps.so.17", INITMODE_QUERY);
- if (wrapper)
- return NewV238(wrapper);
- wrapper = TryToOpen("libgps.so", INITMODE_STREAM);
+ wrapper = TryToOpen("libgps.so");
if (wrapper)
return NewV294(wrapper);
return NULL;
@@ -148,14 +139,12 @@ LibGpsLibraryWrapper::LibGpsLibraryWrapper(void* dl_handle,
gps_open_fn gps_open,
gps_close_fn gps_close,
gps_poll_fn gps_poll,
- gps_query_fn gps_query,
gps_stream_fn gps_stream,
gps_waiting_fn gps_waiting)
: dl_handle_(dl_handle),
gps_open_(gps_open),
gps_close_(gps_close),
gps_poll_(gps_poll),
- gps_query_(gps_query),
gps_stream_(gps_stream),
gps_waiting_(gps_waiting),
gps_data_(NULL) {
@@ -190,14 +179,6 @@ int LibGpsLibraryWrapper::poll() {
return gps_poll_(gps_data_);
}
-// This is intentionally ignoring the va_arg extension to query(): the caller
-// can use base::StringPrintf to achieve the same effect.
-int LibGpsLibraryWrapper::query(const char* fmt) {
- DCHECK(is_open());
- DCHECK(gps_query_);
- return gps_query_(gps_data_, fmt);
-}
-
int LibGpsLibraryWrapper::stream(int flags) {
DCHECK(is_open());
DCHECK(gps_stream_);
diff --git a/content/browser/geolocation/libgps_wrapper_linux.h b/content/browser/geolocation/libgps_wrapper_linux.h
index 6ed6c40..4ef8151 100644
--- a/content/browser/geolocation/libgps_wrapper_linux.h
+++ b/content/browser/geolocation/libgps_wrapper_linux.h
@@ -53,7 +53,6 @@ class CONTENT_EXPORT LibGps {
// libgps API versions (v2.38 => libgps.so.17, v2.94 => libgps.so.19).
// See LibGps::New() for the public API to this.
// Takes ownership of |dl_wrapper|.
- static LibGps* NewV238(LibGpsLibraryWrapper* dl_wrapper);
static LibGps* NewV294(LibGpsLibraryWrapper* dl_wrapper);
scoped_ptr<LibGpsLibraryWrapper> library_;
@@ -71,8 +70,6 @@ class CONTENT_EXPORT LibGpsLibraryWrapper {
typedef gps_data_t* (*gps_open_fn)(const char*, const char*);
typedef int (*gps_close_fn)(gps_data_t*);
typedef int (*gps_poll_fn)(gps_data_t*);
- // v2.34 only
- typedef int (*gps_query_fn)(gps_data_t*, const char*, ...);
// v2.90+
typedef int (*gps_stream_fn)(gps_data_t*, unsigned int, void*);
typedef bool (*gps_waiting_fn)(gps_data_t*);
@@ -81,7 +78,6 @@ class CONTENT_EXPORT LibGpsLibraryWrapper {
gps_open_fn gps_open,
gps_close_fn gps_close,
gps_poll_fn gps_poll,
- gps_query_fn gps_query,
gps_stream_fn gps_stream,
gps_waiting_fn gps_waiting);
~LibGpsLibraryWrapper();
@@ -90,7 +86,6 @@ class CONTENT_EXPORT LibGpsLibraryWrapper {
bool open(const char* host, const char* port);
void close();
int poll();
- int query(const char* fmt);
int stream(int flags);
bool waiting();
const gps_data_t& data() const;
@@ -101,7 +96,6 @@ class CONTENT_EXPORT LibGpsLibraryWrapper {
gps_open_fn gps_open_;
gps_close_fn gps_close_;
gps_poll_fn gps_poll_;
- gps_query_fn gps_query_;
gps_stream_fn gps_stream_;
gps_waiting_fn gps_waiting_;
diff --git a/content/content_browser.gypi b/content/content_browser.gypi
index 4725ca8..f7dc5b6 100644
--- a/content/content_browser.gypi
+++ b/content/content_browser.gypi
@@ -185,7 +185,6 @@
'browser/geolocation/geolocation_provider.h',
'browser/geolocation/gps_location_provider_linux.cc',
'browser/geolocation/gps_location_provider_linux.h',
- 'browser/geolocation/libgps_2_38_wrapper_linux.cc',
'browser/geolocation/libgps_2_94_wrapper_linux.cc',
'browser/geolocation/libgps_wrapper_linux.cc',
'browser/geolocation/libgps_wrapper_linux.h',
diff --git a/third_party/gpsd/README.chromium b/third_party/gpsd/README.chromium
index 1f1bd3e..88a8130 100644
--- a/third_party/gpsd/README.chromium
+++ b/third_party/gpsd/README.chromium
@@ -1,11 +1,11 @@
Name: gpsd
URL: http://git.berlios.de/cgi-bin/gitweb.cgi?p=gpsd;a=summary
InfoURL: http://gpsd.berlios.de/
-Version: 2.38
+Version: 2.94
License: BSD
Description:
-versions 2.38, 2.94
+versions 2.94
gpsd is a service daemon that monitors one or more GPSes or AIS receivers
attached to a host computer through serial or USB ports, making all data on the
location/course/velocity of the sensors available to be queried on TCP port
@@ -14,6 +14,6 @@ location/course/velocity of the sensors available to be queried on TCP port
Local Modifications:
No modifications.
Only the gps.h file is imported, as the client library (libgps.so) is
-dynamically loaded (where present). We import 2 versions as the older (2.38) is
-needed for Chrome OS and the newer for tip of tree builds (using the new client
-API that aims to maintain binary compatibility across future releases).
+dynamically loaded (where present).
+
+Security Critical: yes
diff --git a/third_party/gpsd/release-2.38/gps.h b/third_party/gpsd/release-2.38/gps.h
deleted file mode 100644
index 79cfab8..0000000
--- a/third_party/gpsd/release-2.38/gps.h
+++ /dev/null
@@ -1,651 +0,0 @@
-/* $Id$ */
-#ifndef _GPSD_GPS_H_
-#define _GPSD_GPS_H_
-
-/* gps.h -- interface of the libgps library */
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include <sys/types.h>
-#include <sys/time.h>
-#include <stdbool.h>
-#include <inttypes.h> /* stdint.h would be smaller but not all have it */
-#include <limits.h>
-#include <time.h>
-#include <signal.h>
-#ifndef S_SPLINT_S
-#include <pthread.h> /* pacifies OpenBSD's compiler */
-#endif
-
-#define MAXTAGLEN 8 /* maximum length of sentence tag name */
-#define MAXCHANNELS 20 /* maximum GPS channels (*not* satellites!) */
-#define SIRF_CHANNELS 12 /* max channels allowed in SiRF format */
-#define GPS_PRNMAX 32 /* above this number are SBAS satellites */
-
-/*
- * The structure describing an uncertainty volume in kinematic space.
- * This is what GPSes are meant to produce; all the other info is
- * technical impedimenta.
- *
- * All double values use NAN to indicate data not available.
- *
- * Usually all the information in this structure was considered valid
- * by the GPS at the time of update. This will be so if you are using
- * a GPS chipset that speaks SiRF binary, Garmin binary, or Zodiac binary.
- * This covers over 80% of GPS products in early 2005.
- *
- * If you are using a chipset that speaks NMEA, this structure is updated
- * in bits by GPRMC (lat/lon, track, speed), GPGGA (alt, climb), GPGLL
- * (lat/lon), and GPGSA (eph, epv). Most NMEA GPSes take a single fix
- * at the beginning of a 1-second cycle and report the same timestamp in
- * GPRMC, GPGGA, and GPGLL; for these, all info is guaranteed correctly
- * synced to the time member, but you'll get different stages of the same
- * update depending on where in the cycle you poll. A very few GPSes,
- * like the Garmin 48, take a new fix before more than one of of
- * GPRMC/GPGGA/GPGLL during a single cycle; thus, they may have different
- * timestamps and some data in this structure can be up to 1 cycle (usually
- * 1 second) older than the fix time.
- *
- * Error estimates are at 95% confidence.
- */
-struct gps_fix_t {
- double time; /* Time of update, seconds since Unix epoch */
- int mode; /* Mode of fix */
-#define MODE_NOT_SEEN 0 /* mode update not seen yet */
-#define MODE_NO_FIX 1 /* none */
-#define MODE_2D 2 /* good for latitude/longitude */
-#define MODE_3D 3 /* good for altitude/climb too */
- double ept; /* Expected time uncertainty */
- double latitude; /* Latitude in degrees (valid if mode >= 2) */
- double longitude; /* Longitude in degrees (valid if mode >= 2) */
- double eph; /* Horizontal position uncertainty, meters */
- double altitude; /* Altitude in meters (valid if mode == 3) */
- double epv; /* Vertical position uncertainty, meters */
- double track; /* Course made good (relative to true north) */
- double epd; /* Track uncertainty, degrees */
- double speed; /* Speed over ground, meters/sec */
- double eps; /* Speed uncertainty, meters/sec */
- double climb; /* Vertical speed, meters/sec */
- double epc; /* Vertical speed uncertainty */
-};
-
-/*
- * From the RCTM104 2.x standard:
- *
- * "The 30 bit words (as opposed to 32 bit words) coupled with a 50 Hz
- * transmission rate provides a convenient timing capability where the
- * times of word boundaries are a rational multiple of 0.6 seconds."
- *
- * "Each frame is N+2 words long, where N is the number of message data
- * words. For example, a filler message (type 6 or 34) with no message
- * data will have N=0, and will consist only of two header words. The
- * maximum number of data words allowed by the format is 31, so that
- * the longest possible message will have a total of 33 words."
- */
-#define RTCM2_WORDS_MAX 33
-#define MAXCORRECTIONS 18 /* max correction count in type 1 or 9 */
-#define MAXSTATIONS 10 /* maximum stations in almanac, type 5 */
-/* RTCM104 doesn't specify this, so give it the largest reasonable value */
-#define MAXHEALTH (RTCM2_WORDS_MAX-2)
-
-#ifndef S_SPLINT_S
-/*
- * A nominally 30-bit word (24 bits of data, 6 bits of parity)
- * used both in the GPS downlink protocol described in IS-GPS-200
- * and in the format for DGPS corrections used in RTCM-104v2.
- */
-typedef /*@unsignedintegraltype@*/ uint32_t isgps30bits_t;
-#endif /* S_SPLINT_S */
-
- typedef enum {gps, glonass, galileo, unknown} navsystem;
-
-struct rtcm2_t {
- /* header contents */
- unsigned type; /* RTCM message type */
- unsigned length; /* length (words) */
- double zcount; /* time within hour: GPS time, no leap secs */
- unsigned refstaid; /* reference station ID */
- unsigned seqnum; /* message sequence number (modulo 8) */
- unsigned stathlth; /* station health */
-
- /* message data in decoded form */
- union {
- struct {
- unsigned int nentries;
- struct rangesat_t { /* data from messages 1 & 9 */
- unsigned ident; /* satellite ID */
- unsigned udre; /* user diff. range error */
- unsigned issuedata; /* issue of data */
- double rangerr; /* range error */
- double rangerate; /* range error rate */
- } sat[MAXCORRECTIONS];
- } ranges;
- struct { /* data for type 3 messages */
- bool valid; /* is message well-formed? */
- double x, y, z;
- } ecef;
- struct { /* data from type 4 messages */
- bool valid; /* is message well-formed? */
- navsystem system;
- enum {local, global, invalid} sense;
- char datum[6];
- double dx, dy, dz;
- } reference;
- struct { /* data from type 5 messages */
- unsigned int nentries;
- struct consat_t {
- unsigned ident; /* satellite ID */
- bool iodl; /* issue of data */
- unsigned int health; /* is satellite healthy? */
-#define HEALTH_NORMAL (0) /* Radiobeacon operation normal */
-#define HEALTH_UNMONITORED (1) /* No integrity monitor operating */
-#define HEALTH_NOINFO (2) /* No information available */
-#define HEALTH_DONOTUSE (3) /* Do not use this radiobeacon */
- int snr; /* signal-to-noise ratio, dB */
-#define SNR_BAD -1 /* not reported */
- unsigned int health_en; /* health enabled */
- bool new_data; /* new data? */
- bool los_warning; /* line-of-sight warning */
- unsigned int tou; /* time to unhealth, seconds */
- } sat[MAXHEALTH];
- } conhealth;
- struct { /* data from type 7 messages */
- unsigned int nentries;
- struct station_t {
- double latitude, longitude; /* location */
- unsigned int range; /* range in km */
- double frequency; /* broadcast freq */
- unsigned int health; /* station health */
- unsigned int station_id; /* of the transmitter */
- unsigned int bitrate; /* of station transmissions */
- } station[MAXSTATIONS];
- } almanac;
- /* data from type 16 messages */
- char message[(RTCM2_WORDS_MAX-2) * sizeof(isgps30bits_t)];
- /* data from messages of unknown type */
- isgps30bits_t words[RTCM2_WORDS_MAX-2];
- } msg_data;
-};
-
-/* RTCM3 report structures begin here */
-
-#define RTCM3_MAX_SATELLITES 64
-#define RTCM3_MAX_DESCRIPTOR 31
-#define RTCM3_MAX_ANNOUNCEMENTS 32
-
-struct rtcm3_rtk_hdr { /* header data from 1001, 1002, 1003, 1004 */
- /* Used for both GPS and GLONASS, but their timebases differ */
- unsigned int msgnum; /* Message number */
- unsigned int station_id; /* Reference Station ID */
- time_t tow; /* GPS Epoch Time (TOW) in ms,
- or GLONASS Epoch Time in ms */
- bool sync; /* Synchronous GNSS Message Flag */
- ushort satcount; /* # Satellite Signals Processed */
- bool smoothing; /* Divergence-free Smoothing Indicator */
- ushort interval; /* Smoothing Interval */
-};
-
-struct rtcm3_basic_rtk {
- unsigned char indicator; /* Indicator */
- unsigned char channel; /* Satellite Frequency Channel Number
- (GLONASS only) */
- double pseudorange; /* Pseudorange */
- double rangediff; /* PhaseRange – Pseudorange in meters */
- unsigned char locktime; /* Lock time Indicator */
-};
-
-struct rtcm3_extended_rtk {
- unsigned char indicator; /* Indicator */
- unsigned char channel; /* Satellite Frequency Channel Number
- (GLONASS only) */
- double pseudorange; /* Pseudorange */
- double rangediff; /* PhaseRange – L1 Pseudorange */
- unsigned char locktime; /* Lock time Indicator */
- unsigned char ambiguity; /* Integer Pseudorange
- Modulus Ambiguity */
- double CNR; /* Carrier-to-Noise Ratio */
-};
-
-struct rtcm3_network_rtk_header {
- unsigned int msgnum; /* Message number */
- unsigned int network_id; /* Network ID */
- unsigned int subnetwork_id; /* Subnetwork ID */
- time_t time; /* GPS Epoch Time (TOW) in ms */
- bool multimesg; /* GPS Multiple Message Indicator */
- unsigned master_id; /* Master Reference Station ID */
- unsigned aux_id; /* Auxilary Reference Station ID */
- unsigned char satcount; /* count of GPS satellites */
-};
-
-struct rtcm3_correction_diff {
- unsigned char ident; /* satellite ID */
- enum {reserved, correct, widelane, uncertain} ambiguity;
- unsigned char nonsync;
- double geometric_diff; /* Geometric Carrier Phase
- Correction Difference (1016, 1017) */
- unsigned char iode; /* GPS IODE (1016, 1017) */
- double ionospheric_diff; /* Ionospheric Carrier Phase
- Correction Difference (1015, 1017) */
-};
-
-struct rtcm3_t {
- /* header contents */
- unsigned type; /* RTCM 3.x message type */
- unsigned length; /* payload length, inclusive of checksum */
-
- union {
- /* 1001-1013 were present in the 3.0 version */
- struct {
- struct rtcm3_rtk_hdr header;
- struct {
- unsigned ident; /* Satellite ID */
- struct rtcm3_basic_rtk L1;
- } rtk_data[RTCM3_MAX_SATELLITES];
- } rtcm3_1001;
- struct {
- struct rtcm3_rtk_hdr header;
- struct {
- unsigned ident; /* Satellite ID */
- struct rtcm3_extended_rtk L1;
- } rtk_data[RTCM3_MAX_SATELLITES];
- } rtcm3_1002;
- struct {
- struct rtcm3_rtk_hdr header;
- struct {
- unsigned ident; /* Satellite ID */
- struct rtcm3_basic_rtk L1;
- struct rtcm3_basic_rtk L2;
- } rtk_data[RTCM3_MAX_SATELLITES];
- } rtcm3_1003;
- struct {
- struct rtcm3_rtk_hdr header;
- struct {
- unsigned ident; /* Satellite ID */
- struct rtcm3_extended_rtk L1;
- struct rtcm3_extended_rtk L2;
- } rtk_data[RTCM3_MAX_SATELLITES];
- } rtcm3_1004;
- struct {
- unsigned int station_id; /* Reference Station ID */
- navsystem system; /* Which system is it? */
- bool reference_station; /* Reference-station indicator */
- bool single_receiver; /* Single Receiver Oscillator */
- double ecef_x, ecef_y, ecef_z; /* ECEF antenna location */
- } rtcm3_1005;
- struct {
- unsigned int station_id; /* Reference Station ID */
- navsystem system; /* Which system is it? */
- bool reference_station; /* Reference-station indicator */
- bool single_receiver; /* Single Receiver Oscillator */
- double ecef_x, ecef_y, ecef_z; /* ECEF antenna location */
- double height; /* Antenna height */
- } rtcm3_1006;
- struct {
- unsigned int station_id; /* Reference Station ID */
- char descriptor[RTCM3_MAX_DESCRIPTOR+1]; /* Description string */
- unsigned char setup_id;
- } rtcm3_1007;
- struct {
- unsigned int station_id; /* Reference Station ID */
- char descriptor[RTCM3_MAX_DESCRIPTOR+1]; /* Description string */
- unsigned char setup_id;
- char serial[RTCM3_MAX_DESCRIPTOR+1]; /* Serial # string */
- } rtcm3_1008;
- struct {
- struct rtcm3_rtk_hdr header;
- struct {
- unsigned ident; /* Satellite ID */
- struct rtcm3_basic_rtk L1;
- } rtk_data[RTCM3_MAX_SATELLITES];
- } rtcm3_1009;
- struct {
- struct rtcm3_rtk_hdr header;
- struct {
- unsigned ident; /* Satellite ID */
- struct rtcm3_extended_rtk L1;
- } rtk_data[RTCM3_MAX_SATELLITES];
- } rtcm3_1010;
- struct {
- struct rtcm3_rtk_hdr header;
- struct {
- unsigned ident; /* Satellite ID */
- struct rtcm3_extended_rtk L1;
- struct rtcm3_extended_rtk L2;
- } rtk_data[RTCM3_MAX_SATELLITES];
- } rtcm3_1011;
- struct {
- struct rtcm3_rtk_hdr header;
- struct {
- unsigned ident; /* Satellite ID */
- struct rtcm3_extended_rtk L1;
- struct rtcm3_extended_rtk L2;
- } rtk_data[RTCM3_MAX_SATELLITES];
- } rtcm3_1012;
- struct {
- unsigned int msgnum; /* Message number */
- unsigned int station_id; /* Reference Station ID */
- unsigned short mjd; /* Modified Julian Day (MJD) Number */
- unsigned int sod; /* Seconds of Day (UTC) */
- unsigned char leapsecs; /* Leap Seconds, GPS-UTC */
- unsigned char ncount; /* Count of announcements to follow */
- struct {
- unsigned short id;
- bool sync;
- unsigned short interval;
- } announcements[RTCM3_MAX_ANNOUNCEMENTS];
- } rtcm3_1013;
- /* 1014-1017 were added in the 3.1 version */
- struct {
- unsigned int msgnum; /* Message number */
- unsigned int network_id; /* Network ID */
- unsigned int subnetwork_id; /* Subnetwork ID */
- unsigned char stationcount; /* # auxiliary stations transmitted */
- unsigned int master_id; /* Master Reference Station ID */
- unsigned int aux_id; /* Auxilary Reference Station ID */
- double d_lat, d_lon, d_alt; /* Aux-master location delta */
- } rtcm3_1014;
- struct {
- struct rtcm3_network_rtk_header header;
- struct rtcm3_correction_diff corrections[RTCM3_MAX_SATELLITES];
- } rtcm3_1015;
- struct {
- struct rtcm3_network_rtk_header header;
- struct rtcm3_correction_diff corrections[RTCM3_MAX_SATELLITES];
- } rtcm3_1016;
- struct {
- struct rtcm3_network_rtk_header header;
- struct rtcm3_correction_diff corrections[RTCM3_MAX_SATELLITES];
- } rtcm3_1017;
- struct {
- unsigned int msgnum; /* Message number */
- unsigned int ident; /* Satellite ID */
- unsigned int week; /* GPS Week Number */
- unsigned char sv_accuracy; /* GPS SV ACCURACY */
- enum {reserved_code, p, ca, l2c} code;
- double idot;
- unsigned char iode;
- /* ephemeris fields, not scaled */
- unsigned int t_sub_oc;
- signed int a_sub_f2;
- signed int a_sub_f1;
- signed int a_sub_f0;
- unsigned int iodc;
- signed int C_sub_rs;
- signed int delta_sub_n;
- signed int M_sub_0;
- signed int C_sub_uc;
- unsigned int e;
- signed int C_sub_us;
- unsigned int sqrt_sub_A;
- unsigned int t_sub_oe;
- signed int C_sub_ic;
- signed int OMEGA_sub_0;
- signed int C_sub_is;
- signed int i_sub_0;
- signed int C_sub_rc;
- signed int argument_of_perigee;
- signed int omegadot;
- signed int t_sub_GD;
- unsigned char sv_health;
- bool p_data;
- bool fit_interval;
- } rtcm3_1019;
- struct {
- unsigned int msgnum; /* Message number */
- unsigned int ident; /* Satellite ID */
- unsigned short channel; /* Satellite Frequency Channel Number */
- /* ephemeris fields, not scaled */
- bool C_sub_n;
- bool health_avAilability_indicator;
- unsigned char P1;
- unsigned short t_sub_k;
- bool msb_of_B_sub_n;
- bool P2;
- bool t_sub_b;
- signed int x_sub_n_t_of_t_sub_b_prime;
- signed int x_sub_n_t_of_t_sub_b;
- signed int x_sub_n_t_of_t_sub_b_prime_prime;
- signed int y_sub_n_t_of_t_sub_b_prime;
- signed int y_sub_n_t_of_t_sub_b;
- signed int y_sub_n_t_of_t_sub_b_prime_prime;
- signed int z_sub_n_t_of_t_sub_b_prime;
- signed int z_sub_n_t_of_t_sub_b;
- signed int z_sub_n_t_of_t_sub_b_prime_prime;
- bool P3;
- signed int gamma_sub_n_of_t_sub_b;
- unsigned char MP;
- bool Ml_n;
- signed int tau_n_of_t_sub_b;
- signed int M_delta_tau_sub_n;
- unsigned int E_sub_n;
- bool MP4;
- unsigned char MF_sub_T;
- unsigned char MN_sub_T;
- unsigned char MM;
- bool additioinal_data_availability;
- unsigned int N_sup_A;
- unsigned int tau_sub_c;
- unsigned int M_N_sub_4;
- signed int M_tau_sub_GPS;
- bool M_l_sub_n;
- } rtcm3_1020;
- struct {
- unsigned int msgnum; /* Message number */
- unsigned int station_id; /* Reference Station ID */
- unsigned short mjd; /* Modified Julian Day (MJD) Number */
- unsigned int sod; /* Seconds of Day (UTC) */
- unsigned char len; /* # Chars to follow */
- unsigned char unicode_units;
- unsigned char text[128];
- } rtcm3_1029;
- } rtcmtypes;
-};
-
-typedef /*@unsignedintegraltype@*/ unsigned int gps_mask_t;
-
-struct gps_data_t {
- gps_mask_t set; /* has field been set since this was last cleared? */
-#define ONLINE_SET 0x00000001u
-#define TIME_SET 0x00000002u
-#define TIMERR_SET 0x00000004u
-#define LATLON_SET 0x00000008u
-#define ALTITUDE_SET 0x00000010u
-#define SPEED_SET 0x00000020u
-#define TRACK_SET 0x00000040u
-#define CLIMB_SET 0x00000080u
-#define STATUS_SET 0x00000100u
-#define MODE_SET 0x00000200u
-#define HDOP_SET 0x00000400u
-#define VDOP_SET 0x00000800u
-#define PDOP_SET 0x00001000u
-#define TDOP_SET 0x00002000u
-#define GDOP_SET 0x00004000u
-#define DOP_SET (HDOP_SET|VDOP_SET|PDOP_SET|TDOP_SET|GDOP_SET)
-#define HERR_SET 0x00008000u
-#define VERR_SET 0x00010000u
-#define PERR_SET 0x00020000u
-#define ERR_SET (HERR_SET | VERR_SET | PERR_SET)
-#define SATELLITE_SET 0x00040000u
-#define PSEUDORANGE_SET 0x00080000u
-#define USED_SET 0x00100000u
-#define SPEEDERR_SET 0x00200000u
-#define TRACKERR_SET 0x00400000u
-#define CLIMBERR_SET 0x00800000u
-#define DEVICE_SET 0x01000000u
-#define DEVICELIST_SET 0x02000000u
-#define DEVICEID_SET 0x04000000u
-#define ERROR_SET 0x08000000u
-#define CYCLE_START_SET 0x10000000u
-#define RTCM2_SET 0x20000000u
-#define RTCM3_SET 0x40000000u
-#define FIX_SET (TIME_SET|MODE_SET|TIMERR_SET|LATLON_SET|HERR_SET|ALTITUDE_SET|VERR_SET|TRACK_SET|TRACKERR_SET|SPEED_SET|SPEEDERR_SET|CLIMB_SET|CLIMBERR_SET)
- double online; /* NZ if GPS is on line, 0 if not.
- *
- * Note: gpsd clears this flag when sentences
- * fail to show up within the GPS's normal
- * send cycle time. If the host-to-GPS
- * link is lossy enough to drop entire
- * sentences, this flag will be
- * prone to false negatives.
- */
-
- struct gps_fix_t fix; /* accumulated PVT data */
-
- double separation; /* Geoidal separation, MSL - WGS84 (Meters) */
-
- /* GPS status -- always valid */
- int status; /* Do we have a fix? */
-#define STATUS_NO_FIX 0 /* no */
-#define STATUS_FIX 1 /* yes, without DGPS */
-#define STATUS_DGPS_FIX 2 /* yes, with DGPS */
-
- /* precision of fix -- valid if satellites_used > 0 */
- int satellites_used; /* Number of satellites used in solution */
- int used[MAXCHANNELS]; /* PRNs of satellites used in solution */
- double pdop, hdop, vdop, tdop, gdop; /* Dilution of precision */
-
- /* redundant with the estimate elments in the fix structure */
- double epe; /* spherical position error, 95% confidence (meters) */
-
- /* satellite status -- valid when satellites > 0 */
- int satellites; /* # of satellites in view */
- int PRN[MAXCHANNELS]; /* PRNs of satellite */
- int elevation[MAXCHANNELS]; /* elevation of satellite */
- int azimuth[MAXCHANNELS]; /* azimuth */
- int ss[MAXCHANNELS]; /* signal-to-noise ratio (dB) */
-
-#if 0 /* not yet used or filled in */
- /* measurement data */
- double pseudorange[MAXCHANNELS]; /* meters */
- double deltarange[MAXCHANNELS]; /* meters/sec */
- double doppler[MAXCHANNELS]; /* Hz */
- unsigned satstat[MAXCHANNELS]; /* tracking status */
-#define SAT_ACQUIRED 0x01 /* satellite acquired */
-#define SAT_CODE_TRACK 0x02 /* code-tracking loop acquired */
-#define SAT_CARR_TRACK 0x04 /* carrier-tracking loop acquired */
-#define SAT_DATA_SYNC 0x08 /* data-bit synchronization done */
-#define SAT_FRAME_SYNC 0x10 /* frame synchronization done */
-#define SAT_EPHEMERIS 0x20 /* ephemeris collected */
-#define SAT_FIX_USED 0x40 /* used for position fix */
-#endif
-
-#if defined(TNT_ENABLE) || defined(OCEANSERVER_ENABLE)
- /* compass status -- TrueNorth (and any similar) devices only */
- char headingStatus;
- char pitchStatus;
- char rollStatus;
- double horzField; /* Magnitude of horizontal magnetic field */
-#endif
-
-#ifdef OCEANSERVER_ENABLE
- double magnetic_length; /* unitvector sqrt(x^2 + y^2 +z^2) */
- double magnetic_field_x;
- double magnetic_field_y;
- double magnetic_field_z;
- double acceleration_length; /* unitvector sqrt(x^2 + y^2 +z^2) */
- double acceleration_field_x;
- double acceleration_field_y;
- double acceleration_field_z;
- double gyro_output_x;
- double gyro_output_y;
- double temperature;
-#endif
-
- /* where and what gpsd thinks the device is */
- char gps_device[PATH_MAX]; /* only valid if non-null. */
- char *gps_id; /* only valid if non-null. */
- unsigned int baudrate, parity, stopbits; /* RS232 link parameters */
- unsigned int driver_mode; /* whether driver is in native mode or not */
-
- /* RTCM-104 data */
- struct rtcm2_t rtcm2;
- struct rtcm3_t rtcm3;
-
- /* device list */
- int ndevices; /* count of available devices */
- char **devicelist; /* list of pathnames */
-
- /* profiling data for last sentence */
- bool profiling; /* profiling enabled? */
- char tag[MAXTAGLEN+1]; /* tag of last sentence processed */
- size_t sentence_length; /* character count of last sentence */
- double sentence_time; /* sentence timestamp */
- double d_xmit_time; /* beginning of sentence transmission */
- double d_recv_time; /* daemon receipt time (-> E1+T1) */
- double d_decode_time; /* daemon end-of-decode time (-> D1) */
- double poll_time; /* daemon poll time (-> W) */
- double emit_time; /* emission time (-> E2) */
- double c_recv_time; /* client receipt time (-> T2) */
- double c_decode_time; /* client end-of-decode time (-> D2) */
- double cycle, mincycle; /* refresh cycle time in seconds */
-
- /* these members are private */
- int gps_fd; /* socket or file descriptor to GPS */
- void (*raw_hook)(struct gps_data_t *, char *, size_t len, int level);/* Raw-mode hook for GPS data. */
- void (*thread_hook)(struct gps_data_t *, char *, size_t len, int level);/* Thread-callback hook for GPS data. */
-};
-
-extern /*@null@*/ struct gps_data_t *gps_open(const char *host, const char *port);
-int gps_close(struct gps_data_t *);
-int gps_query(struct gps_data_t *gpsdata, const char *fmt, ... );
-int gps_poll(struct gps_data_t *gpsdata);
-void gps_set_raw_hook(struct gps_data_t *gpsdata, void (*hook)(struct gps_data_t *sentence, char *buf, size_t len, int level));
-int gps_set_callback(struct gps_data_t *gpsdata, void (*callback)(struct gps_data_t *sentence, char *buf, size_t len, int level), pthread_t *handler);
-int gps_del_callback(struct gps_data_t *gpsdata, pthread_t *handler);
-
-enum unit {unspecified, imperial, nautical, metric};
-enum unit gpsd_units(void);
-enum deg_str_type { deg_dd, deg_ddmm, deg_ddmmss };
-extern /*@observer@*/ char *deg_to_str( enum deg_str_type type, double f);
-
-extern void gps_clear_fix(/*@ out @*/struct gps_fix_t *);
-extern void gps_merge_fix(/*@ out @*/struct gps_fix_t *,
- gps_mask_t,
- /*@ in @*/struct gps_fix_t *);
-extern unsigned int gps_valid_fields(/*@ in @*/struct gps_fix_t *);
-extern char *gps_show_transfer(int);
-
-extern time_t mkgmtime(register struct tm *);
-extern double timestamp(void);
-extern double iso8601_to_unix(char *);
-extern /*@observer@*/char *unix_to_iso8601(double t, /*@ out @*/char[], size_t len);
-extern double gpstime_to_unix(int, double);
-extern void unix_to_gpstime(double, /*@out@*/int *, /*@out@*/double *);
-extern double earth_distance(double, double, double, double);
-extern double wgs84_separation(double, double);
-
-/* some multipliers for interpreting GPS output */
-#define METERS_TO_FEET 3.2808399 /* Meters to U.S./British feet */
-#define METERS_TO_MILES 0.00062137119 /* Meters to miles */
-#define KNOTS_TO_MPH 1.1507794 /* Knots to miles per hour */
-#define KNOTS_TO_KPH 1.852 /* Knots to kilometers per hour */
-#define KNOTS_TO_MPS 0.51444444 /* Knots to meters per second */
-#define MPS_TO_KPH 3.6 /* Meters per second to klicks/hr */
-#define MPS_TO_MPH 2.2369363 /* Meters/second to miles per hour */
-#define MPS_TO_KNOTS 1.9438445 /* Meters per second to knots */
-/* miles and knots are both the international standard versions of the units */
-
-/* angle conversion multipliers */
-#define GPS_PI 3.1415926535897932384626433832795029
-#define RAD_2_DEG 57.2957795130823208767981548141051703
-#define DEG_2_RAD 0.0174532925199432957692369076848861271
-
-/* gps_open() errno return values */
-#define NL_NOSERVICE -1 /* can't get service entry */
-#define NL_NOHOST -2 /* can't get host entry */
-#define NL_NOPROTO -3 /* can't get protocol entry */
-#define NL_NOSOCK -4 /* can't create socket */
-#define NL_NOSOCKOPT -5 /* error SETSOCKOPT SO_REUSEADDR */
-#define NL_NOCONNECT -6 /* can't connect to host */
-
-#define DEFAULT_GPSD_PORT "2947" /* IANA assignment */
-#define DEFAULT_RTCM_PORT "2101" /* IANA assignment */
-
-#ifdef __cplusplus
-} /* End of the 'extern "C"' block */
-#endif
-
-/* gps.h ends here */
-#endif /* _GPSD_GPS_H_ */
diff --git a/tools/checklicenses/checklicenses.py b/tools/checklicenses/checklicenses.py
index beb6fd1..51578c5 100755
--- a/tools/checklicenses/checklicenses.py
+++ b/tools/checklicenses/checklicenses.py
@@ -226,9 +226,6 @@ PATH_SPECIFIC_WHITELISTED_LICENSES = {
'third_party/gles2_conform/GTF_ES': [ # http://crbug.com/98131
'UNKNOWN',
],
- 'third_party/gpsd/release-2.38/gps.h': [ # http://crbug.com/98132
- 'UNKNOWN',
- ],
'third_party/harfbuzz': [ # http://crbug.com/98133
'UNKNOWN',
],