Raspberry Pi - Pharos Microsoft GPS-360
http://astrobeano.blogspot.com.es/2012/10/pharosmicrosoft-gps-360-on-raspberry-pi.html
I bought a Microsoft GSP-360 USB dongle on eBay as an impulse purchase, toying with the idea of running a Raspberry Pi in my car for live map display or at least route tracking for contributing road traces to the Open Street-Map project.
Just getting my location out of it proved harder than I'd expected.
The front of the dongle has a big Microsoft logo, while the sticker on the back (which has a bright blue LED when active) says:
P/N: X11-49577
360-1000-02
S/N: ...
GPS-360
Tested to comply with FCC standards
Rating: DC 3.5 - 5.5V 70mA
Pharos USA
SiRF Powered
Made in China
For running this with a Raspberry Pi that current information could be useful, and the broad voltage tolerance is reassuring.
What do we learn at the command line? It appears as a Profilic USB/Serial adaptor at the USB level - here's what my Mac tells me:
$ system_profiler SPUSBDataType
|
And in Linux, running on a Raspberry Pi (with no other devices attached):
$ lsusb
|
USB/Serial Drivers
I should be able to talk to the USB-serial port, but to do on the Mac it seems I must first install a Prolific USB-serial driver. That's what this and this helpful blog told me.
Finding the Prolific USB/serial driver for Mac OS X took a while, it was hiding behind a "GUEST"/"GUEST" password protected page - but I eventually found md_PL2303_MacOSX10.6_dmg_v1.4.0.zip released 2011/05/13 which claims to support OS X 10.8 Mountain Lion.
There's also an open source driver, osx-pl2303 on SourceForge (SVN latest updated Jan 2008), forked as osx-pl2303 on Github (last updated Nov 2011), reported to have been tested under Mac OS X 10.7 Lion and 10.8 Mountain Lion. I punted on this.
As an aside, finding drivers for older versions of Windows was quite easy, but Profilic won't support their older PL-2303HXA and PL-2303X chips under Windows 8, using this as a stick to encourage people to buy their newer PL2303TA chip instead. Ouch.
For Linux there drivers should be already installed - so I went with that. Here's an excerpt from the Raspberry Pi boot log (with the GSP-360 dongle as the only external USB device plugged in):
$ dmseg
|
As per that log, the new serial port is available as /dev/ttyUSB0
$ ls -l /dev/ttyUSB0
|
I'm using the default image here, username 'pi', and I am therefore a member of the dialout group so should be able to connect to this device:
$ groups
|
Strangely I didn't (immediately) get anything from the device using a low level check:
$ cat /dev/ttyUSB0
|
GPSD
It seems the main low-level GPS software for Linux is gpsd, so I installed that and tried to run it.
$ sudo apt-get install gpsd gpsd-clients
|
Encouragingly the GPSD hardware page says support for the Microsoft GPS-360 is good, they test it before each release, and it should be plumbed into the Linux hotplug system to start gpsd automatically.
Rebooting with the GPS attached should create /dev/gps0 as an alias for /dev/ttyUSB0 and start the gpsd daemon automatically, check with:
$ ps -e | grep gpsd
|
In this case it is running (with process identifier 307). Similarly, if you boot up without the dongle and then plug it in, it should be recognised as gpsd started automatically. If it is running, this should kill it (advice from the GPSD Troubleshooting page):
$ sudo killall gpsd
|
You can (re)start it manually with:
$ gpsd /dev/ttyUSB0
|
I then tried a little test (with the daemon off):
$ gpsctl -f -n /dev/ttyUSB0
gpsctl:SHOUT: vendor/product match with 091e:0003 not found
|
That isn't good... the -f meant without using the deamon mode of gpsd, the -n meant switch to NMEA mode. When it works I got this and could look at the raw NMEA output:
$ gpsctl -f -n /dev/ttyUSB0
|
$ cat /dev/ttyUSB0
|
Incidentally, until I read this blog post about why GPS support sucks, I'd been under the impression that NMEA 0183 was a good standard.
The GPSD Troubleshooting suggests starting with xgps or cgps. When cgps works:
$ cgps
|
I've masked out my exact location. Note CPU usage running gpsd and cgps with the default SiRF binary protocol was about 8%.
However, after rebooting and immediately running cgps it starts, waits for a bit with missing location information, then quits with a time out:
$ cgps
|
I also ran into this:
$ gpsctl -n /dev/ttyUSB0
|
And:
$ cat /dev/ttyUSB0
|
I'm not quite sure what is going on here. I suspect a problem in how gpsd is started automatically (possibly Debian or Raspian specific?). What does seem to work is a cold restart (from power off) with the dongle attached, log in, kill and restart gpsd, and then run cgps.
GPS Babel
The Open Street-Map on their instructions for uploading GPS tracks request GPX format and recommend GPS Babel to generate this. At the time of writing the latest release is GPSBabel 1.4.4, the repository hasn't caught up yet as this gave me v1.4.3:
$ sudo apt-get install gpsbabel
|
$ gpsbabel -V
|
Then (provided that everything was co-operating - see above), I could use the gpsd utility to switch the output to NMEA mode, capture some of that to a file, and convert it into GPX format using gpsbabel:
$ gpsctl -f -n /dev/ttyUSB0
|
In principle that should work with the SiRF binary format, but perhaps something is going wrong when I try to capture a random section with since the GPX file is essentially empty (valid XML, but no actual data unlike the NMEA capture above):
$ gpsctl -f /dev/ttyUSB0
|
That was rather tortuous. But with the rough edges sorted out could work as the basis of a GPS track logger.
Update 1
Here's a link to Peter Mount's blog post using a GPS dongle and Raspberry Pi as an NTP server (Network Time Protocol), useful as a way to set the clock on a RPi as it has no internal battery like a normal PC - meaning it needs a network connection or other external system to set the time and date. It seems he is also wondering about connecting his Raspberry Pi to his telescope...
Update 2
Here's a link to David Taylor's GSP based Raspberry Pi NTP server page, incredibly detailed including how to use Pulse Per Second (PPS) for improved precision.
0 comentarios:
Post a Comment