Chinaunix首页 | 论坛 | 博客
  • 博客访问: 108984
  • 博文数量: 13
  • 博客积分: 489
  • 博客等级: 一等列兵
  • 技术积分: 175
  • 用 户 组: 普通用户
  • 注册时间: 2011-02-12 10:06
文章分类

全部博文(13)

文章存档

2011年(13)

分类: LINUX

2011-02-17 09:56:41

TI平台使用SIRF GPS
2.Android HAL的实现
(1)制作libgps.so库
google提供的方法
 
Android.mk:
LOCAL_SRC_FILES:= main.c    //指定库的源码
LOCAL_MODULE := libgps    //指定库的名称
include $(BUILD_SHARED_LIBRARY)    //指定编译成.so库
 
(2)修改BoardConfig.mk
添加BOARD_GPS_LIBRARIES := libgps
 
由于hardware/libhardware_legacy/gps/Android.mk中指定LOCAL_SHARED_LIBRARIES
ifneq ($(BOARD_GPS_LIBRARIES),)
  LOCAL_CFLAGS           += -DHAVE_GPS_HARDWARE
  LOCAL_SHARED_LIBRARIES += $(BOARD_GPS_LIBRARIES)
endif
 
(3)修改hardware/libhardware_legacy/gps/gps.cpp
  1. static void
  2. gps_find_hardware( void )
  3. {
  4.     sGpsInterface = gps_get_hardware_interface();
  5.     if (!sGpsInterface)
  6.         LOGD("no GPS hardware on this device\n");
  7. }
gps_get_hardware_interface()在libgps.so源码中实现
 
(4)实现libgps.so源码main.c
(可参考hardware/libhardware_legacy/gps/gps_qemu.c)
 
  1. static const GpsInterface sirfGpsInterface = {
  2.     sirf_gps_init,
  3.     sirf_gps_start,
  4.     sirf_gps_stop,
  5.     sirf_gps_cleanup,
  6.     sirf_gps_inject_time,
  7.     sirf_gps_inject_location,
  8.     sirf_gps_delete_aiding_data,
  9.     sirf_gps_set_position_mode,
  10.     sirf_gps_get_extension,
  11. };
  12. const GpsInterface* gps_get_hardware_interface()
  13. {
  14.     return &sirfGpsInterface;
  15. }

下面将介绍下需要修改的函数,其他函数都可以仿照gps_qemu.c

sirf_gps_start()函数中添加SiRF_Start();

sirf_gps_stop()函数中添加SiRF_Stop();

sirf_gps_init()函数中调用gps_state_init,作用是创建socket通信和gps_state_thread线程;

gps_state_init()函数中需要根据具体的GPS模块实现state->fd = channel_open();

gps_state_thread()函数中去掉两句nmea_reader_set_callback调用;

nmea_reader_parse()函数添加callbacks.nmea_cb和callbacks.location_cb:

  1. if (r->pos < 9) {
  2.         D("Too short. discarded.");
  3.         return;
  4. }
  5. {
  6.     struct timeval tv;
  7.     gettimeofday(&tv, NULL);
  8.      _gps_state->callbacks.nmea_cb(tv.tv_sec*1000+tv.tv_usec/1000, r->in, r->pos);
  9. }
  10. nmea_tokenizer_init(tzer, r->in, r->in + r->pos);
  1. if (_gps_state->callbacks.location_cb) {
  2.      _gps_state->callbacks.location_cb( &r->fix );
  3.      r->fix.flags = 0;
  4. }
  5. else {
  6.      D("no callback, keeping data until needed !");
  7. }

(5)NMEA数据上报

Android本身的GPS读取NMEA信息机制是调用read函数读取串口信息并解析上报,但SIRF提供了SiRF_Output函数用于底层与应用层的数据上报,GPS工作后会有线程不停调用SiRF_Output,因此只要在SiRF_Output函数中添加:

  1. NmeaReader reader[1];
  2. nmea_reader_init( reader );

  3. for (nn = 0; nn < sizeof(buf); nn++)
  4.      nmea_reader_addc( reader, buf[nn] );

现在GPS可以上报GGA、GSA、RMC等数据(GSA数据需添加nmea_reader_parse函数中关于GSA数据解析)

 

后面还会继续研究GSA等数据的解析上报...期待o ^-^

 

 

阅读(18547) | 评论(24) | 转发(1) |
给主人留下些什么吧!~~

Z-yalinux2011-03-30 09:58:55

lassur: 尝试在andriod源码线程中取消read,直接赋值buff[]="$GPGGA,161229.487,3723.2475,N,12158.3416,W,1,07,1.0,9.0,M, , , ,0000*18";,然后nmea_reader.....
数据格式没什么问题,你把GPS_DEBUG宏打开,看看nmea_reader_parse函数解析后的数据对不对?另外,read不到数据那就要用Sirf提供的读函数,在测试程序代码里估计有。

Z-yalinux2011-03-30 09:48:48

在SiRF_Output中调nmea_reader_addc,只要SiRF_Output线程一跑,nmea_reader_addc会自动往上报数据

人山人嗨2011-03-29 16:15:37

博主你好,我也有个问题,我把NmeaReader加进SiRF_Output里面去了,但是不知道SiRF_Output是被谁调用的?SiRF_Output应该是SIRF公司给的一个函数,ANDROID的上层怎么知道如何调用它?

人山人嗨2011-03-29 16:14:20

博主你好,我也有个问题,我把NmeaReader加进SiRF_Output里面去了,但是不知道SiRF_Output是被谁调用的?SiRF_Output应该是SIRF公司给的一个函数,ANDROID的上层怎么知道如何调用它?

lassur2011-03-29 09:21:54

Z-yalinux: 直接该名字当然不行,qemu_channel_open()是模拟器模拟串口的打开,和真实打开串口方式不一样,你要看你的串口驱动中open函数提供给上层的系统调用.....
本来我打算在JAVA层重写解析函数,对串口的open,read实现了上层的接口,但发现重写nmea不是件简单的事情。请问你做的时候,除了改写自己的open,set,read,其他部分还需要修改么?我老得不到数据