Devuan fork of gpsd
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

871 lines
47 KiB

  1. GPSD project news
  2. 3.20: 2019-12-31
  3. Change README into an asciidoc file and publish HTML from it
  4. Add NED and geoid_sep to gps_fix_t and TPV JSON.
  5. Add "-e NED" to ubxtool to enable NED messages.
  6. gpsdata.separation replaced by gpsdata.fix.geoid_sep.
  7. Remove nofloats build option.
  8. TPV JSON "alt" is now fixed at WGS84. Probably.
  9. xgps now uses XGPSOPTS environment variable.
  10. add health variable to satellite_t
  11. change satellite_t elevation and azimuth to double
  12. satellite_t elevation, azimuth, and ss use NAN for unknown value.
  13. add altMSL, altHAE, and depth, to gps_fix_t
  14. altitude in gps_fix_t is deprecated and undefined
  15. wgs84_separation() now return EGM2008 computed from 5x5 degree base data.
  16. The best results are close to cm, the worst off up to 12m.
  17. Move mag_var from gps_device_t to magnetic_var gps_data_t.
  18. Added mag_var() to interpolate magnetic variation (deviation) from a table.
  19. Remove true2magnetic() as mag_var() improves on it.
  20. Remove TIMEHINT_ENABLE. It only worked when enabled.
  21. Remove NTP_ENABLE and NTPSHM_ENABLE. It only worked when enabled.
  23. Add dgps_age and dgps_station to gps_fix_t
  24. Convert all timestamp_t to timespec_t.
  25. Remove FIXED_PORT_SPEED and FIXED_STOP_BITS build options.
  26. Add -s [speed] and -f [framing] runtime options to gpsd.
  27. A working CC and termios.h are mandatory.
  28. use the current leap second to determine the current GPS epoch.
  29., leapseconds.cache, timebase.h and leapfetch option gone.
  30. See also change histories in gps.h and gpsd.h
  31. 3.19: 2019-07-01
  32. Rearrange rawdata_t. Bump the API because gps_data_t changed.
  33. Report sequence-ID fields in type 7 and 13 AIS messages.
  34. Preliminary support for SiRFstar V
  35. Improve error modeling.
  36. Update pseudo NMEA to v3.0, with fractional time.
  37. Improve cycle detection, mostly for NMEA.
  38. Move epe from gps_data_t to be near its friends in gps_fix_t.
  39. Preliminary u-blox 9 support.
  40. Add qErr in gps_data_t to store PPS quantization error.
  41. Add Android (AOSP) support
  42. Improved multi gnss and multi signal support.
  43. NMEA 4.10 multi gnss multi signal support.
  44. The arguments to "ubxtool -p P" have been expanded and changed.
  45. New options, -g, -x, -z, added to ubxtool for u-blox 9 support.
  46. 3.18.1: 2018-10-19 (Gary E. Miller <>)
  47. Fix some installation issues.
  48. A few minor updates to ubxtool and driver_ubx.
  49. Add contrib/skyview2svg
  50. 3.18: 2018-10-02 (Gary E. Miller <>)
  51. Add ECEF support to ievermore, italk,Skytraq, SiRF, U-blox drivers.
  52. Add ECEF support to JSON, cgps and xgps.
  53. Add GREIS (Javad) driver from Virgin Orbit.
  54. Add CLI tools zerk and ubxtool to manage JAVAD and u-blox GPS.
  55. Add gnssid:svid to satellite_t, cgps and xgps. PRN will die.
  56. Add gnssid:svid to JSON, cgps and xgps.
  57. Add stricter version checking (more to todo).
  58. More and better regression tests.
  59. Better Python dependency checking, at build time and runtime.
  60. Fix several buffer issues.
  61. New polar plots, and improved statistice, in gpsprof.
  62. gpsd master/slave mode works, first time ever.
  63. All isnan() changed to !isfinite(), fixing many bugs.
  64. Client-side Python libraries may automatically reconnect
  65. Too many other bug fixes and improvements to mention.
  66. Over 1,000 commits from 46 different commiters.
  67. 3.17: 2017-09-07 (Eric S. Raymond <>)
  68. Repair support for non-NMEA devices requring active probing
  69. (e.g. Garmin USB GPSes). Apply OS X build fixes. Fix a SiRF driver
  70. bug that occasionally confused NTP. Support for Spectratime iSync
  71. GRClok and LNRClok oscillators. gpxlogger can reconnect when
  72. the GPS loses the fix. xgps and xgpsspeed moved to python-gi,
  73. getting shut of the deprecated pygtk2 bindings. Default mode for
  74. xgpsspeed is now the more interesting nautical display. gpsmon
  75. includes the hostname with the device display. gpsprof now has
  76. centimeter precision.
  77. 3.16: 2016-01-08 (Eric S. Raymond <>)
  78. Test rebuilds for mid-2015 leapsecond bump. Regression tests will
  79. run even if "python" in Python 3. Build correctly on systems where
  80. -ltinfo is split from -lncurses. Avoid some rare overflow conditions
  81. in PPS code. Fix bugs in JSON sat-view parsing due to the JSON
  82. parser stuffing ints into shorts. Various small fixes to AIS
  83. interpretation. Prevent a memory leak in long-running gpsmon
  84. instances. Fix Savannah bug #45270: serial driver does not work
  85. properly on pipes. Fix Savannah bug #44648: GPSD won't build if
  86. CCFLAGS contains options that are only compatible with the
  87. cros1s-compiler. Fix Savannah bug #45342: SConstruct generates wrong
  88. *.pc files. Fix Savannah bug #46495: gpsd_poll may crash due to
  89. unitialized pointer (probably due to buggy FD_ISSET on host
  90. system). Fix Savannah bug #46648: gpsd crashes and buffer overflow
  91. is reported when terminated. Fix Savannah bug #46802: AIVDM to CSV
  92. is broken in some weird cases. Fix Savannah bug #46804: JSON
  93. satellite view parsing is somewhat broken.
  94. 3.15: 2015-06-03 (Eric S. Raymond <>)
  95. Fix a rare crash bug related to devices becoming inaccessible while timed out.
  96. Accept NMEA 4.1 GSV sentences with the trailing signal-ID field.
  97. Fixed incorrect decode of south latitudes in AIS Type 17 messages.
  98. splint has been retired; this removes almost 2KLOC of annotations.
  99. chrpath is no longer a build dependency. Corrected Beidou/QZNSS display
  100. in the Python clients so the graphics don't look like SBAS.
  101. 3.14: 2015-03-14 (Eric S. Raymond <>)
  102. The Pi Day release, 3.14 on 3/14 2015 at 9:26. Longer timeouts on test clients.
  103. Skyview support for the Beidou and QZSS constellations in the NMEA0183 driver.
  104. ntpmon rename to ntpshmmon - it doesn't actually monitor NTP itself.
  105. New HOWTO on the website: "Introduction to Time Service".
  106. 3.13: 2015-02-26 (Eric S. Raymond <>)
  107. compiler.h inclusion removed for gps.h so it's standalone for /usr/include.
  108. TOFF JSON report gives the offset between GPS top of second and clock time.
  109. A new ntpmon tool supports capturing clock samples from NTP SHM segments.
  110. 3.12: 2015-02-22 (Eric S. Raymond <>)
  111. The daemon's power utilization has been reduced by changing from
  112. non-blocking to blocking I/O; this may be significant on mobile devices.
  113. Better protection against false matches of Inland AIS messages; this
  114. required a libgps version bump to 22 (as a side effect, per-device
  115. footprint has decreased). PPS feature is no longer marked
  116. experimental/unstable. Sentence tag fields have been dropped from
  117. the JSON reports. GNSS and GLONASS SKY reports are now
  118. merged. Addressed versions of AIS Type 25 and 26 are now
  119. handled. The 'nmea' build option is now 'nmea0183'. New 'minimal'
  120. option sets all boolean options not explicitly set on the build
  121. command line to false. The 'limited_max_devices' option is now
  122. 'max_devices'; the 'limited_max_clients' option is now 'max_clients'
  123. The previously deprecated 'libQgpsmm' option has been removed; use 'qt'.
  124. A bug fix for error modeling when NMEA 0183 reports empty DOP
  125. fields. On OS X, the "osx-pl203" driver has been explicitly listed
  126. as unsupported. The last remnants of the old pre-JSON query protocol
  127. have been removed from the client library.
  128. 3.11: 2014-07-23 (Eric S. Raymond <>)
  129. A bug that prevented track interpolation has been fixed.
  130. We now get vertical error position and speed estimates from the
  131. u-blox driver rather than having to interpolate them.
  132. Some unusual AIS talker IDs (NMEA 4.0 station classes) are supported.
  133. chrpath is no longer a dependency for building and testing, and
  134. now defaults to 'no'. Full systemd support. Fixes for handling
  135. large PPS offsets. Improved recovery from device flakeouts,
  136. gpsmon argument parsing.
  137. 3.10: 2013-11-22 (Eric S. Raymond <>)
  138. AIS: Adds gps2udp, an AIS data relay, split24 option supports
  139. passing through Type 24 halves; support for Inland AIS; "scaled" no
  140. longer controls dumping of controlled-vocabulary fields; instead,
  141. the're always dumped numerically and as text, with text in an
  142. attribute name generated by appending "_text" to the name of the
  143. base attribute. The packetizer's handling of write boundaries not
  144. coinciding with packet boundaries is improved. Better support for
  145. mode and speed switching in the UBX driver. PPS message now ships
  146. nsec. PPS events are visible in gpsmon. Time-reporting fix to TSIP.
  147. 3.9: 2013-05-01 (Eric S. Raymond <>)
  148. Note to packagers: this is an urgent release that fixes a possible
  149. DoS or security hole! Armor the AIS driver against an implausible
  150. overrun attack. A (different) fix for our first malformed-packet
  151. crash since about 2007. Minor improvements to the NMEA2000
  152. driver. New FAQ entry on how to know WAAS/EGNOS is working.
  153. New -u and -uu options enable usec timestamps on gpspipe output.
  154. 3.8: 2013-02-25 (Eric S. Raymond <>)
  155. Fix various minor errors in the AIVDM/AIVDO description. Repair the
  156. xmlto support in the build system. Add two more regression
  157. tests. Significant improvements to NMEA2000 support. Upgrade the PHP
  158. client to v3 of the Google Maps API. Support for the Telit SL869
  159. chipset. Added a nautical-style display to xgpsspeed. Minor
  160. improvements to
  161. 3.7: 2012-07-02 (Eric S. Raymond <>)
  162. Snap release to get the midnight change in the default leap-second
  163. constant out the door. Port tests now pass on all Debian supported
  164. architectures, including the Sparc and s390 that were giving us
  165. trouble before. Pre-2003 Delorme Earthmate works again.
  166. 3.6: 2012-05-23 (Eric S. Raymond <>)
  167. It's the Fernando Poo Day release. Code has zero detectible defects
  168. under Coverity scanning and cppcheck 1.52; this is mainly a cleanup
  169. release to get those minor fixes into the field. If a leap-second
  170. warning is available from GPS subframe information it is passed to
  171. ntpd. NMEA2000 is now supported via the Linux kernel CAN interface.
  172. There's a chrpath=no config option for distribution makers, so
  173. chrpath is no longer a build dependency; see build.txt for
  174. explanation.
  175. 3.5: 2012-04-14 (Eric S. Raymond <>)
  176. Use pselect when it's available to cut down on wakeups and improve
  177. signal handling. New {PPS} message exporting clock drift. The AIVDM
  178. driver now handles up to 16 interleaved 24A and 24B pair-halves.
  179. The NMEA driver interprets depth-sounder returns from SDDBT and
  180. reports them as negative altitudes. The pps-pin option is gone, the
  181. PPS code now just accepts any handshake pin. A bug that sometimes
  182. caused RTCM packets to be dropped rather than relayed is fixed.
  183. 3.4: 2012-01-12 (Eric S. Raymond <>)
  184. Don't barf when chrpath is not available, fall back to static linking;
  185. helps people not running Linux.
  186. 3.3: 2011-10-29 (Eric S. Raymond <>)
  187. Improvements to build and release-procedure documentation. Make
  188. sirf=no build work again. Main reason for this release is to make
  189. chrpath a mandatory build dependency and explain why in the build
  190. documentation.
  191. 3.2: 2011-10-25 (Eric S. Raymond <>)
  192. In the build recipe, (1) set pkgconfig properly for 64-bit Fedora
  193. systems, (2) clean up various derived files including *.pyc on scons
  194. -c, (3) add an option to disable stripping of binaries (strip=no),
  195. (4) for embedded targets, add an option to disable building Python
  196. support (python=no), (5) make the help for gpsd_group and gpsd_user
  197. a little clearer, (6) add a force_global option to build gpsd to
  198. listen to all addresses (rather than just loopback). The packet
  199. sniffer now accepts NMEA packets with the ECDIS packet leader 'EC'.
  200. SBAS satellites are now properly use-flagged in SiRF and UBX
  201. skyviews. The -G option now works under IPv6. Cross-build is now
  202. officially supported and instructions included. gpsprof works again
  203. and does whole-cycle profiling. gpsd.php has Open Street Map
  204. support. The pp-on-cts option is replaced by a pps_pin option that
  205. lets you specify the pin; the default is still DCD. New supported
  206. device; the Jackson Labs Fury. The chrpath utility has become a
  207. build prerequisite.
  208. 3.1: 2011-07-28 (Eric S. Raymond <>)
  209. The Irene release, rocking you like a hurricane and brought to you
  210. from the storm shelter in my basement. This is a snap release mainly
  211. to get some scons recipe cleanups out the door. Parallelized builds
  212. now work. Small but fatal problems with reconfigure=no, netfeed=no
  213. and sock_export=no builds have been fixed. Build recipe ported for
  214. Fedora, Darwin, FreeBSD and OpenBSD. libgps now brings -lm with it
  215. on systems with implicit linking. One old bug fixed (code was
  216. previously present but broken): Under Linux, gpsd will refrain from
  217. opening serial or USB devices that another process has open,
  218. avoiding potential problems with class 0xFF USB devices opened by
  219. other programs. One new bug fix: we now use an atof()
  220. implementation that ignores locale, avoiding problems where decimal
  221. point is a comma. One new feature: Change -N semantics so it only
  222. suppresses backgrounding; privileges are now dropped as in normal
  223. background operation.
  224. 3.0: 2011-07-19 (Eric S. Raymond <>)
  225. POLL subobject name changes: fixes -> tpv, skyview -> sky.
  226. Fix a timestamp-clobbering bug in the C library revealed by an
  227. obscure car-nav device, the MyGuide 3100. The DEVICE 'activated'
  228. attribute becomes an ISO8601 string; the client libraries will
  229. still backward-compatibly read a float value. gps_unpack() is
  230. now a documented part of the library API. There is now a
  231. shared-memory export from the daemon that can be accessed through
  232. the C and C++ client libraries. xgps and cgps may now display
  233. the Maidenhead grid locator for current lat/lon. xgps displays
  234. GST noise statistics if they are available. Codebase now has
  235. an scons build recipe. Direct support for activation of gpsd from
  236. Mac OS/X systemd. gpsdecode can now filter reports by RTCM2, RTCM3,
  237. or AIS message type. NMEA HEHDT is implemented. Remote gpsd instances
  238. can now be used as data sources via a gpsd:// URL. There is a client
  239. for live-feeding GPSD data to Google Earth. The hotplug sequence no
  240. longer requires Python.
  241. 2.96: 2011-03-21 (Eric S. Raymond <>)
  242. Bumped maximum channel count to 32 to accommodate GPS+GLONASS devices.
  243. API version bumped to 5, redesign finished (changes are documented
  244. in the Client HOWTO). cgps now handles resize signals. Code can now
  245. link with uClibc for embedded use. Various bugs in the C++ binding
  246. have been fixed. gpxlogger can now daemonize and write to a specified
  247. log file. A gpsd client can now set any locale it likes, and JSON
  248. will still be parsed using the C locale matching the daemon's. Clients
  249. are no longer required to define a gpsd_report() hook. gpsd no longer
  250. emits probe strings to unidentified USB devices at startup.
  251. JSON timestamps in TPV and SKY are now ISO8601 rather than seconds since
  252. the Unix epoch; the library handles the older style backward-compatibly.
  253. GPGST sentences are now parsed for noise statistics when a device emits them.
  254. AIS and RTCM2 JSON dumps have device fields. JSON reports now include 50bps
  255. subframe data if the device allows access to it. gpsdecode can now dump NMEA
  256. GPS binary, and subframe data to JSON. The RTCM2 code now understands and
  257. analyzes RTCM2.3 messages 13, 14, and 31, and has been checked against another
  258. analyzer. The ancient Sager dump format for RTCM2 is abolished in favor of
  259. a JSON profile.
  260. 2.95: 2010-07-13 (Eric S. Raymond <>)
  261. The autonomous robot submarine total world domination release!
  262. Rationalize clearing and generation of DOPs, this makes epx/epy much
  263. more generally available. Fixed the test productions for the udev
  264. magic and added a troubleshooting note in INSTALL. cgps now displays
  265. epx/epy rather than eph. Speed is now always reported if our last
  266. two fixes were good, even if the GPS didn't compute it. Reading
  267. packets from UDP datagrams by specifying a listening address and
  268. port is now supported, and the regression-test driver cam now be
  269. told to force this with -u; this enables regression testing in
  270. chroot jails where access to ptys is locked out. AIS code now
  271. interprets message type 6 and 8 application IDs correctly as a
  272. Designated Area Code and Functional ID pair. gpspipe has a new -T
  273. option for setting the timestamp format. xgpsspeed is completely
  274. rewritten in Python, eliminating some dependencies on ancient X
  275. libraries. We now ship a Qt binding for the client library. Note
  276. a GCC 4.2.1 optimizer bug. gpsdcode now uses | as a field separator
  277. in -c mode, as string fields can contain commas. Corrected error
  278. in reporting of AIS rate-of-turn fields.
  279. 2.94: 2010-04-20 (Eric S. Raymond <>)
  280. Error-checking in the 50bps subframe code has been greatly improved.
  281. The Garmin GPS driver can now use libusb, if it is present, to do
  282. device discovery. The libgps library has been split apart; the
  283. service functions used by the daemon now live in libgpsd. This
  284. will shave some code volume from GPSD client applications. A packaging
  285. error that resulted in xgps not being shipped in 2.93 has been
  286. corrected. We now have stronger checking for valid ephemeris before
  287. extracting the leap-second offset; they should prevent many cases
  288. where gpsd might previously have used an invalid leap-second offset.
  289. 2.93: 2010-04-16 (Eric S. Raymond <>)
  290. Support for JSON dumping and parsing of AIS message types 25 and 26,
  291. not yet observed in the wild on AISHub. Fix Debian bug #569703. by
  292. removing non-streaming mode from the Python exerciser. Fix Debian
  293. bug #572900 by unsetting the appropriate in-use flag in the device
  294. array. Change the libgps default from old protocol to JSON. Add a
  295. close() method to the C++ binding. Try to recover better from
  296. sporadic cases of false matches to Trimble packet format from a SiRF
  297. binary datastream. gps_poll() now returns -1 with errno not set when
  298. the gpsd socket closes. TPV now refrains from reporting fields the
  299. fix quality won't support. gpsmon option for listing device types is
  300. now -L to -l can be used to enable logging (to stay consistent with
  301. the l command). There is new FAQ material on improving fix and time
  302. reference accuracy. New sections have been added to NMEA.txt on
  303. error status indications and satellite IDs. New POLL command brings
  304. back polling-mode operation. A Client-HOWTO has been added to the
  305. documentation. gpsd no longer eats CPU when a device is unexpectedly
  306. unplugged. Support for the TNT revolution is back (run mode only).
  307. There is now a gpsdfake diagnostic tool that fakes being gpsd shipping
  308. arbitrary specified data to clients.
  309. 2.92: 2010-03-03 (Eric S. Raymond <>)
  310. Fix a packaging error. The new Python library module was
  311. inadvertently omitted from the 2.91 tarball. Also, improve the json
  312. import test slightly.
  313. 2.91: 2010-03-01 (Eric S. Raymond <>)
  314. We have support for NMEA GLONASS sentences, and a regression test.
  315. Clients now get a DEVICE notification on every driver switch. It is
  316. possible to specify a TCP/IP AIS feed such as AISHub as a data
  317. source. Serious bitrot in the NTRIP support has been fixed - it was
  318. probably nonfunctional for several releases before this. Fixed
  319. buggy display of satellite-used flags in cgps. xgps is replaced by
  320. a rewrite in Python that uses pygtk, eliminating a dependency on
  321. Motif; also, it now displays AIS information. Uniform treatment of
  322. display-unit defaulting and -u in xgps, cgps, and lcdgps. Support
  323. for AIS message types 25 and 26. Support for IPv6. A numeric
  324. instability in the earth_distance() function affecting track error
  325. modeling has been fixed. Old protocol has been removed from the
  326. daemon; the library still speaks it.
  327. 2.90: 2009-12-04 (Eric S. Raymond <>)
  328. GPSD-NG, the new JSON-based command protocol, is now deployed; as a
  329. consequence, AIS is now fully supported in both daemon and client.
  330. Detection of end of a fix-reporting cycle is now reliable;
  331. accordingly data is accumulated from cycle start and the "J"
  332. (nojitter) option on both server and client side is gone. We have
  333. abandoned the gpsflash subproject since it has become apparent that
  334. we can't do it without more vendor cooperation than we're likely to
  335. get. Increase major version of shared library due to significant API
  336. change. Added new driver for Motorola Oncore receivers, with help
  337. from HÃ¥kan Johansson. gpsfake can now accept multiple logfiles,
  338. interleaving test sentences from each. gpsd now accepts error
  339. estimates from the NMEA $GPGBS sentence.
  340. 2.39: 2009-03-18 (Eric S. Raymond <>)
  341. Fixed potential core dump in C client handling of "K" responses.
  342. Made device hotplugging work again; had been broken by changes in udev.
  343. Introduced major and minor API version symbols into the public interfaces.
  344. The sirfmon utility is gone, replaced by gpsmon which does the same
  345. job for multiple GPS types. Fixed a two-year old error in NMEA parsing
  346. that nobody noticed because its only effect was to trash VDOP values from
  347. GSA sentences, and gpsd computes those with an internal error model
  348. when they look wonky. cgpxlogger has been merged into gpxlogger.
  349. Speed-setting commands now allow parity and stop-bit setting if the
  350. GPS chipset and adaptor can support it. Specfile and other packaging
  351. paraphenalia now live in a packaging subdirectory. rtcmdecode becomes
  352. gpsdecode and can now de-armor and dump AIDVM packets. The client
  353. library now works correctly in locales where the decimal separator is
  354. not a period.
  355. 2.38: 2009-02-10 (Eric S. Raymond <>)
  356. Regression test load for RoyalTek RGM3800 and Blumax GPS-009 added.
  357. Scaling on E error-estimate fields fixed to match O. Listen on
  358. localhost only by default to avoid security problems; this can be
  359. overridden with the -G command-line option. The packet-state machine
  360. can now recognize RTCM3 packets, though support is not yet complete.
  361. Added support for ublox5 and mtk-3301 devices. Add a wrapper around
  362. gpsd_hexdump to save CPU. Lots of little fixes to various packet
  363. parsers. Always keep the device open: "-n" is not optional any more.
  364. xgpsspeed no longer depends on Motif. gpsctl can now ship arbitrary
  365. payloads to a device. It's possible to send binary through the
  366. control channel with the new "&" command. Experimental new driver
  367. for Novatel SuperStarII. The 'g' mode switch command now requires,
  368. and returns, 'rtcm104v2' rather than 'rtcm104'; this is design forward
  369. for when RTCM104v3 is fully working.
  370. 2.37: 2008-02-17 (Chris Kuethe <>)
  371. The C++ bindings, Garmin USB support, and multiple instances of ntp
  372. pps thread starting were fixed. Handling of odd PPS signals was
  373. improved. The eye candy in the PHP visualizers was fixed.
  374. 2.36: 2008-01-01 (Eric S. Raymond <>)
  375. Urgent fix to leap-day calculation affecting dates from today to
  376. 28 Feb on generic NMEA GPSes, Zodiacs, and SirFs emitting message 0x62.
  377. Integrated Garmin Simple Text Protocol driver from Peter Slansky.
  378. Minor fixes in error modeling and a better NaN guard stabilize the
  379. Trimble regression tests. Remove the wired-in NTP time offset from the
  380. NMEA driver, this could only have worked by accident and should be
  381. set in ntpd.conf. Integrated Ashtech driver from Chris Kuethe.
  382. 2.35: 2007-12-10 (Eric S. Raymond <>)
  383. Navcom driver merged. Removed -d -f and -p options of gpsd; these
  384. have been undocumented for a while. Make gpsd play well with pkgconfig.
  385. Incorrect computation of VDOP when GPSes didn't supply it has been fixed.
  386. The xgps code has been revamped and now has a much nicer interface.
  387. Add -b (no-configuration) option as a sadly clumsy workaround for some
  388. problems with Bluetooth receivers. Added tests for Haicom-305N and Pharos
  389. 360; separated out the tests for the unstable Trimble drivers.
  390. 32-vs-64-bit problems in the regression tests have been solved.
  391. 2.34: 2006-12-14 (Eric S. Raymond <>)
  392. Fix for byte-swapping of Zodiac control messages on big-endian hardware.
  393. Disable iTalk by default and note that it needs to be tested. Command line
  394. arguments can now be DGPSIP or NTRIP URLs; -d is deprecated. Added udev
  395. rules. Address excessive processor and memory utilization on SBCs; it's
  396. now possible to configure compile-time limits on the number of devices
  397. and client sessions. Eliminate use of fuser(1) in gpsfake. Get gpsd
  398. working with EarthMates again, this had been broken since 2.15. Massive
  399. string safety audit and OpenBSD port by Chris Kuethe. J command added.
  400. The gpsctl and gpscat tools and the gpsd.phps script were added. Switched
  401. to lesstif from openmotif. Better autodetection of DLE-led packet
  402. protocols (notably TSIP and Garmin binary) and of SiRFStar I and III
  403. devices. Fixed buggy parsing and generation of PGRME.
  404. 2.33: 2006-06-09 (Eric S. Raymond <>)
  405. Fix bad unit conversion in V output. Clean up some man-page messes.
  406. Fixed buggy libgps parsing of multiple responses. It's now possible
  407. to lock gpsd to a fixed speed at compile time for embedded use. Added
  408. NTRIP support, thanks to Ville Nuorvala. O command now ships an
  409. explicit mode field.
  410. 2.32: 2006-03-12 (Eric S. Raymond <>)
  411. Cleanup of the xgps layout, and minor memory-leak fixes for xgps. Fix
  412. to cope with Antares u-blox by Andreas Stricker. Minor fix to libgps
  413. cgpxlogger. Merge cgpxlogger and gpxlogger documentation onto
  414. the xgps(1) manual page and rename it gps(1).
  415. 2.31: 2006-02-17 (Eric S. Raymond <>)
  416. Now builds and runs under Cygwin. Correct the speed units in
  417. synthetic NMEA. Slightly better time handling under NMEA. Daemon
  418. now builds with all but NMEA disabled. Update the leap-second
  419. offset. cgpxlogger introduced. Upgrade gpxlogger to DBUS 0.60
  420. conformance. Jason von Nieda's patch may fix the chronic TSIP
  421. driver problems.
  422. 2.30: 2005-09-14 (Eric S. Raymond <>)
  423. Prevent core dump on -d option. The .log extension is no longer required for
  424. test loads. cgps and xgps now have configurable latitude/longitude formats
  425. via the -l option. Introduced new 'g' command that allows clients to
  426. specify whether they want GPS or RTCM104 information.
  427. 2.29: 2005-07-19 (Eric S. Raymond <>)
  428. Added Sony CXD2951 support, untested. All error estimates are
  429. now nailed to 95% confidence interval. Added rtcmdecode and its
  430. documentation; also, gpsd can now monitor serial devices emitting
  431. RTCM104 and display differential-GPS data in a readable format.
  432. Added dangerous alpha version of gpsflash. Work around a nasty bug
  433. in SiRFStar III firmware version < 3.1.1. Added support for True
  434. North Technologies Revolution 2X Digital compass. Added the
  435. gpxlogger client for systems with DBUS support and the gpspipe
  436. and cgps clients for general use.
  437. 2.28: 2005-07-06 (Eric S. Raymond <>)
  438. The 2.27 source tarball somehow got truncated on upload.
  439. Due to procedural mechanics at Berlios, shipping a new release
  440. seems to be the least painful way to recover. This release is
  441. identical to 2.27 except the roadmap stuff has been added to TODO.
  442. 2.27: 2005-07-06 (Eric S. Raymond <>)
  443. Arrange for the daemon to remove its pid file on exit. Fix some
  444. buffering problems with the Python side of the hotplug interface.
  445. gpsfake can now run sessions under a monitor like Valgrind. Most
  446. of the gpsfake logic now lives in a module that can be used to write
  447. other test loads; its progress baton is now optional. Fixed
  448. some minor bugs found by valgrind audit, including (1) a slow
  449. memory leak, (2) a possible but unconfirmed file-descriptor leak,
  450. and (3) a subtle error in the channel-assignment logic that only
  451. showed up with multiple sessions active. In fact, the daemon code
  452. no longer uses dynamic-memory allocation at all. Also, the code
  453. no longer relies on FIONREAD working. The track error field in the
  454. O response is now computed. The project website has some new eye candy.
  455. Client connections now time out when the mode is neither raw nor watcher.
  456. Fixed a core-dump that could happen if C, B or I commands were issued
  457. at odd times.
  458. 2.26: 2005-06-22 (Eric S. Raymond <>)
  459. Time DOP and total DOP are now passed on from GPSes that report
  460. them. Ensure longitude has a leading zero when <100, for
  461. compatibility with gpsdrive. Synchronous and thread hooks are now
  462. separate in the client library. Packet-sniffing on a new device no
  463. longer holds up incoming data on already-connected ones. There is
  464. now a super-raw mode (R=2) that dumps a hex-encoding of every binary
  465. packet received to the client; sirfmon uses it to operate through
  466. the daemon if one is running. Support for Trimble TSIP GPSes
  467. merged. gpsfake now works with SiRF and Zodiac logs. Python library
  468. supports thread callbacks. New -p option of gpsfake supports
  469. regression testing of the daemon, and there is a test suite included
  470. with the distribution. PPS support is turned off, as there is some
  471. pthreads problem that sometimes kills the daemon on pthreads exit.
  472. Correct off-by-one error in GPZDA processing. The code has been
  473. audited and cleaned with splint (
  474. 2.25: 2005-05-21 (Eric S. Raymond <>)
  475. Various signedness and scaling fixes and an OpenBSD port patch for the
  476. Zodiac driver. Command-line arguments to gpsd are now treated as a default
  477. device list; -f is still supported but deprecated. sirfmon now tries not
  478. changing the line speed first, so it syncs up much faster. Prevent a
  479. potential buffer overrun in the client library. PPS-thread support is now
  480. on by default. Lots of documentation improvements. D-BUS broadcast support
  481. by Amaury Jacquot. Added Alfredo Pironti's thread-callback and C++
  482. support. gpsd no longer uses the system clock for anything, so it
  483. can be used to set that clock.
  484. 2.24: 2005-05-17 (Eric S. Raymond <>)
  485. Crazy-speed bug is finally fixed. Autobauding now starts with the
  486. current speed of the device, not the stored gpsd speed; this means
  487. hunting only takes place when device and GPS speed aren't matched.
  488. xgpsspeed unit-conversion bug introduced in 2.22 is fixed. Satellite
  489. display now really shows 12 channels, not just 11. Major improvements
  490. in ntp notifications.
  491. 2.23: 2005-05- 4 (Eric S. Raymond <>)
  492. For better security, the daemon now drops root privileges after startup.
  493. gpsd-clients is now a separate RPM; this is helpful on lean systems
  494. that don't run X. The O command now reports speeds in meters per second
  495. rather than knots, client code has been adjusted so there is no user-visible
  496. change. We now compute the missing components of DOP when using SiRF chips.
  497. /dev/gps is no longer special; there is no default GPS device unless you
  498. specify one. The intermittent processor-hogging problem introduced by the
  499. control-channel change in 2.21 has been solved.
  500. 2.22: 2005-04-25 (Eric S. Raymond <>)
  501. SiRF-binary driver can now get leap-second corrections from subframe data.
  502. Device add/delete commands now send back OK or ERROR. Error-modeling
  503. corrections from the SiRF folks. Higher precision in position reports.
  504. 2.21: 2005-04-12 (Eric S. Raymond <>)
  505. Add tag and timestamp to Y response. Use computed geoid separation as
  506. SiRF packet 42 is flaky. Security fix: hotplug scripts now do device
  507. add/removes through a separate local control channel. True multi-device
  508. support is in place. When in watcher mode, device switches are announced.
  509. 2.20: 2005-03-31 (Eric S. Raymond <>)
  510. Rob Janssen's patches to fix timezone issues and improve cooperation
  511. with NTP. License changed to BSD so linking to libgps won't make people
  512. nervous. gpsprobe and are obsolete and have been removed, the
  513. autoprobe and profiling capabilities in the daemon more than replace
  514. them. gpsprof now ships self-contained GNUPLOT scripts to stdout,
  515. so they can be saved and redisplayed. Zodiac sort of works again, but
  516. occasionally spins madly during autobauding.
  517. 2.19: 2005-03-26 (Eric S. Raymond <>)
  518. Fix brown-paper-bag bug with NMEA parsing. Set SiRF GPSes to use
  519. SBAS. sirfmon now displays SBAS parameters, and is included in the
  520. installed programs. Add to FAQ a fix for spurious high speeds reported
  521. in XTrac mode. We now interpret GPZDA. We no longer fudge a missing
  522. ddmmyy in NMEA timestamps from the system clock, so replay will work better.
  523. 2.18-1: 2005-03-23 (Eric S. Raymond <>)
  524. First cut at cooperating with NTP. Major library restructuring;
  525. a fix is now a data structure of its own, and per-field timestamps
  526. are gone. Use new 'o' command for watcher mode. Compute some estimated
  527. error bounds.
  528. 2.17: 2005-03-16 (Eric S. Raymond <>)
  529. Fix packet-engine problem that made disconnect/reconnect unreliable
  530. (important!). Fix bonehead error in interpretation of PGRME. We
  531. don't use O_SYNC (it turned out not to be reliable) so remove it to make
  532. life easier under Mac OS X. Allow gpsfake to accept subsecond cycle times.
  533. Add a FAQ to the HTML documentation. gps_poll() now handles multi-line
  534. responses. Add N command for switching driver modes.
  535. 2.16: 2005-03-11 (Eric S. Raymond <>)
  536. New F command allows changing the GPS device after startup time.
  537. Hotplug scripts to go with it are now installed by the RPM. The
  538. Garmin probe is working. The -T and -s options are gone. We have
  539. achieved zero configuration!
  540. 2.15: 2005-03-02 (Eric S. Raymond <>)
  541. A new packet engine autobauds much more quickly, and now iterates
  542. over both 1 and 2 stopbits. Explicit support for FV18 (the -T f
  543. option) is gone; instead, gpsd syncs with any 7N2 device and always
  544. ships a suitable init string. New E command, supporting the Garmin
  545. position-error sentence or computing these numbers from DOP and an
  546. error model. New U command reports climb/sink from GPSes that report
  547. vertical velocity. There is a prototype driver for SiRF-binary GPses,
  548. invoked automatically when SiRF packets present themselves on the
  549. wire after device open.
  550. 2.14: 2005-02-25 (Eric S. Raymond <>)
  551. Pass zero magnetic variation in generated NMEA from binary GPSes
  552. correctly. Use O_SYNC rather than timeouts to guarantee that
  553. baud-rate change strings get to the GPS before changing the line
  554. parameters. Introduced I command. Spatial scattergram plotting
  555. moved from gpsprobe to gpsprof.
  556. 2.13: 2005-02-21 (Eric S. Raymond <>)
  557. Correct a bug in binary-protocol dumping (applies to Zodiac and
  558. Garmin only). Gary Miller's patch to deal gracefully with GPSes
  559. like the Magellan EC10X that send only GPRMC and never GPGGA or
  560. GPGSA, and thus never set mode or status fields. Fixed buggy
  561. handling of units options in xgps and xgpsspeed. Bumped library
  562. major version, since seen_sentences is now exposed and drivers have
  563. more capabilities. Stricter NMEA buffer validation. Withdrew the
  564. change that always passed up a timestamp; on SiRF receivers, the year
  565. part is garbage when the PVT fields are garbage. Can now recognize
  566. SiRF GPSes. Experimental baud-switching support for Zodiac.
  567. 2.12: 2005-02-15 (Eric S. Raymond <>)
  568. Fixed core-dump bug in processing of the GLL variant that does not
  569. include an FAA Mode Indicator. When using the NMEA driver, gpsd now
  570. hunts for a baud rate rather than requiring a fixed one to be set.
  571. A new 'B' command returns the RS232 parameters, and a new 'C'
  572. command returns the update cycle time. Added gpsfake test harness.
  573. Alpha driver for Garmin binary protocol added, requires Linux
  574. garmin_usb kernel driver. The daemon now always passes up a
  575. timestamp for every sentence that has one, even if the PVT fields
  576. aren't valid.
  577. 2.11: 2005-02-10 (Eric S. Raymond <>)
  578. Added gpsprof and the capability to generate GPS latency profiles.
  579. gpsprobe now hunts through plausible baud rates when looking for NMEA
  580. data from a GPS. The -b (baudrate) option fixes a speed, disabling
  581. the baud-matching logic. Also, gpsprobe can now recognize SiRF
  582. protocol, though not speak it. Fixed a math domain error in
  583. gps.EarthDistance due to numeric blowup on points very close together,
  584. and another in gps.MeterOffset() that was screwing up gpsprobe plots.
  585. 2.10: 2005-02-01 (Eric S. Raymond <>)
  586. Add -N option to explicitly foreground the daemon. Fixed a bug
  587. that was causing gpsd to keep reopening the GPS device after
  588. leaving raw or watcher mode. Fixed Gary Miller's core-dump bug.
  589. 2.9: 2005-01-27 (Eric S. Raymond <>)
  590. Python files restored to RPM.
  591. 2.8: 2005-01-27 (Eric S. Raymond <>)
  592. Embarrassing typo fix in Avoid buffer overrun in xgps.c.
  593. Plug Debian security bug 292347, CVE number CAN-2004-1388.
  594. This version issued on an emergency basis without Python libraries,
  595. which have packaging problems due to the 2.3/2.4 transition.
  596. 2.7: 2005-01-14 (Eric S. Raymond <>)
  597. More compiler-warning cleanups. gps client name changed to xgps.
  598. Added --speedunits option to xgpsspeed, --speedunits and --altunits
  599. options to xgps. Improved GPGSV parsing so it copes gracefully if
  600. we start in the middle of a sequence. Merged Petter Reinholdtsen's
  601. fix for GPGSA lists with holes. In xgps, satellites used in the
  602. last fix are now dotted in the middle. New -P option to create
  603. pidfile. Audited for potential buffer overruns, found and fixed
  604. two.
  605. 2.6: 2005-01-01 (Eric S. Raymond <>)
  606. Petter Reinholdtsen's fix for buffering. Fix syntax errors
  607. in udev scriptlets. Clean up after GCC warning messages. Drop use of
  608. vsprintf, so we get a link-time error on systems that might produce
  609. buffer overruns (all modern Unixes support vsnsprintf which is safe).
  610. 2.5: 2004-12-23 (Eric S. Raymond <>)
  611. Use gmtime instead of localtime when guessing the day or year of a date;
  612. this avoids jitter in the day after 19:00 GMT. Added -v option to dump
  613. version and exit. Commented out a crash-causing debug line in
  614. 2.4: 2004-12-09 (Eric S. Raymond <>)
  615. Minor bugs in fixed. M now returns 0 status if GPGSA not yet
  616. seen; this change also fixes a bug where gpsd claimed it was confused
  617. if GPGSA had not been seen and status was set. RPM will now install
  618. a udevd rule if the host system uses it. Don't set the online flag
  619. on activate. HP port changes and -Wall cleanup. James Cameron's
  620. fixes to clean up gps.c and use X timeouts rather than alarms.
  621. 2.3: 2004-10-25 (Eric S. Raymond <>)
  622. Documentation and comment fixes. Last two globals removed from
  623. low-level interface; library should now be fully re-entrant. Mac OS X
  624. port fixes. Q command fix from Robin L Darroch <>.
  625. 2.2: 2004-10-18 (Eric S. Raymond <>)
  626. Documentation improvements. BSD port fixes. Bug fix: speed timestamp
  627. wasn't initialized properly in libgps. Device is now an optional
  628. command-line argument of gpsprobe, in line with the clients.
  629. now should handle fvwm devices correctly. Values in gps data
  630. panel are now labeled with units. Attempted fix for 2.1 bug of DTR
  631. not being pulled low on exit.
  632. 2.1: 2004-09-30 (Eric S. Raymond <>)
  633. Various internal cleanups, including fossil removal in the
  634. configuration machinery. FV-18, Tripmate, Earthmate and are now
  635. enabled but can be disable with --disable-$NAME at configure time.
  636. When you call configure with --disable-shared, libgps is linked
  637. statically to the binaries (native libs are still linked
  638. shared). Fixed buggy handling of -p option in gps.c and xgpsspeed.c;
  639. it's now an optional command-line argument.
  640. 2.0: 2004-09-16 (Eric S. Raymond <>)
  641. Packaging fixes for 2.0 release.
  642. 1.98: 2004-09-08 (Eric S. Raymond <>)
  643. Only do one getdtablesize() call, otherwise we do several
  644. getrlimits() each poll cycle. TripMate is working. gpsprobe now
  645. deduces NMEA version. Zodiac Earthmate seems to work.
  646. 1.97: 2004-08-08 (Eric S. Raymond <>)
  647. Removed PRWIZCH support (it still passes through in raw mode).
  648. Build Motif-dependent programs conditionally. Added gpsprobe.
  649. Fixed a brown-paper-bag-bug in 1.96 RPM packaging.
  650. 1.96: 2004-08-31 (Eric S. Raymond <>)
  651. Implemented non-blocking writes to clients, so a stalled client
  652. cannot stall gpsd. Fixed a nasty array-overrun bug. Timestamps
  653. are now in ISO8601 format, with sub-second precision if the GPS
  654. delivers that. First cuts at Python interfaces included. libgps.a
  655. interface now bundles session fd into an allocated session block.
  656. Automake-based build machinery from Jens Oberender; RPM now
  657. installs shared libraries. FV18 driver added. Offline timer in GPS.
  658. 1.95: 2004-08-25 (Eric S. Raymond <>)
  659. Fixed broken 'make dist', missing display.c and Tachometer.c
  660. are in there now.
  661. 1.94: 2004-08-24 (Eric S. Raymond <>)
  662. Fix embarrassing bug -- watcher mode did not work for more than one
  663. client at a time. Y command now carries information about which
  664. satellites were used in the last fix. New timeout mechanism, no
  665. longer dependent on FIONREAD.
  666. 1.93: 2004-08-23 (Eric S. Raymond <>)
  667. Fourth prerelease. Daemon-side timeouts are gone, they complicated
  668. the interface without adding anything. Command responses now
  669. contain ? to tag invalid data. -D2 feature of 1.92 backed out.
  670. 1.92: 2004-08-22 (Eric S. Raymond <>)
  671. Third prerelease. Clients in watcher mode now get notified when
  672. the GPS goes online or offline. Major name changes -- old libgps
  673. is new libgpsd and vice-versa (so the high-level interface is more
  674. prominent). Specfile now includes code to install gpsd so it will
  675. be started at boot time. -D2 now causes command error messages
  676. to be echoed to the client.
  677. 1.91: 2004-08-21 (Eric S. Raymond <>)
  678. Second pre-2.0 release. Features a linkable C library that hides the
  679. details of communicating with the daemon. The daemon now recovers
  680. gracefully from having the GPS unplugged and plugged in at any time;
  681. one of the bits of status it can report is whether the GPS is online.
  682. The gps and xgpsspeed clients now query the daemon; their code
  683. for direct access to the serial port has been deliberately removed.
  684. 1.90: 2004-08-15 (Eric S. Raymond <>)
  685. Creation of specfile.
  686. ?: 2004-03-21 (Remco Treffkorn <>)
  687. Without PRWIZCH sentence: sat. colors in gps according to ss, grey==lt20,
  688. yellow==lt40 else green.
  689. Added L Q and I to the protocol. Removed G and T.
  690. Changed the timeout mechanism. Try to not return Lat/Lon/Alt if
  691. validity is in doubt.
  692. ?: 2004-01-29 (Remco Treffkorn <>)
  693. Make applications null-terminate their resource lists.
  694. ?: 2003-12-20 (Remco Treffkorn <>)
  695. Removed <varargs.h> from netlib. Not needed, and new gcc does not support
  696. it any more.
  697. 1.10: 2003-08-20 (Remco Treffkorn <>)
  698. Add install target. Fix clean target. Make GPS timeout configurable.
  699. Make xgpsspeed build with Apple's X11.
  700. Make sure that we don't segfault if the NMEA is badly formed.
  701. ?: 2003-08-18 (Remco Treffkorn <>)
  702. Use cfset[io]speed() to set speed in serial.h. Glibc is quite insane
  703. and I am tired to chase it, so I give up. Hope this works for BSD.
  704. Set status and mode 0 after GPS timeout (5 sec) - Cougar <>
  705. 1.09: 2003-02-16 (Remco Treffkorn <>)
  706. Include sys/time.h in gpsd.c for struct timeval.
  707. ?: 2002-11-03 (Remco Treffkorn <>)
  708. G or g command returns six-digit Maidenhead grid square (like FN12fx)
  709. 1.08: 2002-10-03 (Remco Treffkorn <>)
  710. Added sockopt SO_REUSEADDR to netlib.c passive_sock.
  711. 1.07: 2002-02-05 (Remco Treffkorn <>)
  712. em.c uses <time.h> (as it should). Removed some <sys/time.h>
  713. where they were not needed.
  714. Russ Nelson: Improved Earthmate support: added state machine for
  715. EARTHA recognizer, removed alignment problems seen on ARM architecture.
  716. Added setsockopt to add SO_REUSEADDR, so that
  717. gpsd can stop and immediately restart. Added support for bitrates
  718. higher than 38400, needed for the SIRF chipset.
  719. Derrick: my patch causes longitude when under 100 degrees to be printed
  720. zero-padded as needed, the latitude same deal under 10, fixes the GGA
  721. sentence to not erroneously print fix type (2/3) instead of fix quality,
  722. and calculates fix type correctly.
  723. 1.06: 2000-08-11 (Remco Treffkorn <>)
  724. Change from C++ (/) to C comments (/* */)for compatibility.
  725. Added -n (need init) flag.
  726. Don't init unless lat/lon specified.
  727. Remove as the default hostname.
  728. 1.05: 2000-05-12 (Remco Treffkorn <>)
  729. (even though version.h says 1.04)
  730. Added some includes to xgpsspeed.c for portability.
  731. Fix problem with flags being overwritten, and using the wrong port
  732. variable also in xgpsspeed.c
  733. Add a note about Y2K compatibility fix.
  734. Pass latitude and longitude into em_init().
  735. 1.02: 2000-03-17 (Remco Treffkorn <>)
  736. (even though version.h says 1.01)
  737. 1.01: 2000-03-05 (Remco Treffkorn <>)
  738. Updated to IANA port. Fixes to DGPS support.
  739. 1.0: 2000-01-02 (Remco Treffkorn <>)
  740. Added DGPS fixes from Curt Mills. (See README for contact info.)
  741. 0.99dgps: 1999-12-13 (Remco Treffkorn <>)
  742. Added minimal DGPS support by Derrick J Brashear
  743. 0.99: 1999-07-17 (Remco Treffkorn <>)
  744. Rockwell binary is now translated to NMEA format, so that
  745. clients like gps will work with an EarthMate.
  746. Added speedometer application. Thanks to Derrick J Brashear
  747. for his work (see README for contact info).
  748. 0.96: 1999-03-04 (Remco Treffkorn <>)
  749. Changed EarthMate support. Rockwell binary is now almost properly
  750. supported. Only the minimum required information is extracted.
  751. 0.95: 1999-02-06 (Remco Treffkorn <>)
  752. Added support for EarthMate receivers. Since I do not have one, this is
  753. untested.
  754. If it works, it does the following: You start gpsd with a baudrate of 9600
  755. and give it the -Te option. If gpsd gets the EartMate it will enable the
  756. receiver and then attempt to switch it into NMEA mode. If the EarthMate id
  757. is not received, but a binary data header is received, then we will try to
  758. switch NMEA too.
  759. 0.94: 1999-01-24 (Remco Treffkorn <>)
  760. Y2K compliant ;-) (... is NOT. Look for "FIXME:" in nmea_parse.c)
  761. 0.93: 1998-01-27 (Remco Treffkorn <>)
  762. using GNU autoconf now.
  763. combined gpsd + gpsclient. No more init files, command line only.
  764. 0.9: 1997-05-13 (Remco Treffkorn <>)
  765. some cleanups in the ini code. version 0.9 ...
  766. 0.8: 1997-04-25 (Remco Treffkorn <>)
  767. version 0.8, some bug fixes. New MODE member, STATUS member changed.
  768. 0.7: 1997-04-21 (Remco Treffkorn <>)
  769. released version 0.7