Difference between revisions of "AirborneCodeReorg"
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
	
| Line 4: | Line 4: | ||
| Fixed wing airframes have makefile directly in them - we can't change anything in the airborne code without breaking everybody's airframe | Fixed wing airframes have makefile directly in them - we can't change anything in the airborne code without breaking everybody's airframe | ||
|   ap.srcs += commands.c | |||
|   ap.CFLAGS += -DACTUATORS=\"servos_4015_MAT_hw.h\" -DSERVOS_4015_MAT | |||
|   ap.srcs += $(SRC_ARCH)/servos_4015_MAT_hw.c actuators.c | |||
|   ap.CFLAGS += -DRADIO_CONTROL | |||
|   ap.srcs += radio_control.c $(SRC_ARCH)/ppm_hw.c | |||
|   [...]  | |||
|   ap.CFLAGS += -DNAV -DAGR_CLIMB -DLOITER_TRIM -DALT_KALMAN -DWIND_INFO | |||
|   ap.srcs += nav.c fw_h_ctl.c fw_v_ctl.c | |||
| Booz uses "susbsystem" Makefiles | Booz uses "susbsystem" Makefiles | ||
| Line 38: | Line 47: | ||
| =Replace makefile section with xml= | =Replace makefile section with xml= | ||
| of course leave the possibility to have a makefile section, but the normal user would have something like | of course leave the possibility to have a makefile section, but the normal user would have something like | ||
| {| border=1 width=100% | |||
| | airframe.xml  | |||
| |rowspan=2| -> | |||
| | Makefile.ac  | |||
| |- | |||
| | | |||
|    <target name="booz2_autopilot"> |    <target name="booz2_autopilot"> | ||
|       <subsystem name="radio_control" type="ppm"/> |       <subsystem name="radio_control" type="ppm"/> | ||
| Line 44: | Line 58: | ||
|       <subsystem name="imu" type="b2v1"/> |       <subsystem name="imu" type="b2v1"/> | ||
|    </target> |    </target> | ||
| |  | |||
|  include $(PAPARAZZI_SRC)/conf/autopilot/booz2_common.makefile | |||
|   include $(CFG_BOOZ)/booz2_autopilot.makefile | |||
|   include $(CFG_BOOZ)/subsystems/booz2_radio_control_ppm.makefile | |||
|   include $(CFG_BOOZ)/subsystems/booz2_actuators_mkk.makefile | |||
|   include $(CFG_BOOZ)/subsystems/booz2_imu_b2v1.makefile | |||
| |} | |||
| put defines in here that get written in airframe.h | put defines in here that get written in airframe.h | ||
Revision as of 15:07, 16 August 2010
Problem statement
Current airborne code has gone a little bit out of control and is in deep need of a reorganization.
Fixed wing airframes have makefile directly in them - we can't change anything in the airborne code without breaking everybody's airframe
ap.srcs += commands.c ap.CFLAGS += -DACTUATORS=\"servos_4015_MAT_hw.h\" -DSERVOS_4015_MAT ap.srcs += $(SRC_ARCH)/servos_4015_MAT_hw.c actuators.c ap.CFLAGS += -DRADIO_CONTROL ap.srcs += radio_control.c $(SRC_ARCH)/ppm_hw.c [...] ap.CFLAGS += -DNAV -DAGR_CLIMB -DLOITER_TRIM -DALT_KALMAN -DWIND_INFO ap.srcs += nav.c fw_h_ctl.c fw_v_ctl.c
Booz uses "susbsystem" Makefiles
include $(PAPARAZZI_SRC)/conf/autopilot/booz2_common.makefile include $(CFG_BOOZ)/booz2_autopilot.makefile include $(CFG_BOOZ)/subsystems/booz2_radio_control_ppm.makefile include $(CFG_BOOZ)/subsystems/booz2_actuators_mkk.makefile include $(CFG_BOOZ)/subsystems/booz2_imu_b2v1.makefile
This is the Makefile part of a booz vehicle using a booz2 IMU, mikrokopter actuators and ppm radio control
There is also the "module" facility which is very good for optional features.
There are 3 kinds of code in the airborne directory
- generic code (that doesn't depend on any architecture or plateforme) - there's a lot of it and it should probably be sorted by type of functionalities
- processor specific code (stm32, lpc21, avr, etc...)
- plateforme specific code (tiny, booz, lisa, etc...)
Coding Style
Proposed reorganization
- Move more code to modules
- Move Makefile out of the airframe file as much as possible (modules have there own makefile / booz include makefile approach: "conf/autopilot/fixedwing_common.makefile")
- Send mailing list message requesting to change the makefile section of airframes into new include structure
- Once many users have this in place and the wiki page is good, we can start to move code
Replace makefile section with xml
of course leave the possibility to have a makefile section, but the normal user would have something like
| airframe.xml | -> | Makefile.ac | 
|  <target name="booz2_autopilot">
    <subsystem name="radio_control" type="ppm"/>
    <subsystem name="actuators" type="mkk"/>
    <subsystem name="imu" type="b2v1"/>
 </target>
 | include $(PAPARAZZI_SRC)/conf/autopilot/booz2_common.makefile include $(CFG_BOOZ)/booz2_autopilot.makefile include $(CFG_BOOZ)/subsystems/booz2_radio_control_ppm.makefile include $(CFG_BOOZ)/subsystems/booz2_actuators_mkk.makefile include $(CFG_BOOZ)/subsystems/booz2_imu_b2v1.makefile | 
 
put defines in here that get written in airframe.h
<target name="booz2_autopilot">
    <subsystem name="actuators" type="mkk">
      <define name="NB" value="4"/>
      <define name="ADDR" value="{ 0x52, 0x54, 0x56, 0x58 }"/>
    </subsystem> 
    <subsystem name="imu" type="b2v1"/>
 </target>
set makefile variables
 <target name="booz2_autopilot">
    <subsystem name="gps" type="ubx">
      <param name="GPS_UART_NR" value="1"/>
      <param name="GPS_BAUD"    value="38400"/>
    </subsystem> 
 </target>