Software Components
      Most of the software we write that flies in space is written in SPARK, a subset of the
      Ada programming language that supports program
      verification. With the use of appropriate tools SPARK programs can be mathematically
      proved free of runtime error and they can have other correctness properties proved as
      well.
     
    
      Basic Low Earth Orbit
      Our basic low earth orbit CubeSat uses the SPARK 2005 language. As far as we are aware
      our CubeSat is the first spacecraft of any kind to use SPARK (although other spacecraft
      have used Ada). We should note, however, that some of the low level drivers and a third
      party library for manipulating our SD card are written in C. We hope to minimize the
      amount of C in future missions.
      Our software makes no use of an operating system but instead runs on the bare metal.
      The SPARK code was compiled with all checks suppressed, which we felt was justified by
      using the SPARK tools to prove the program free of runtime error (see below for more
      information). This also allowed us to eliminate the Ada runtime system from the
      executable, saving space and further reducing the amount of unproved code used.
      
      We used the Texas
      Instruments MSP430 microcontroller due to its exceptionally low power consumption and
      our prior experience with it in the Alaskan
      Ice Buoy project. Unfortunately when we started our project there was no Ada compiler
      available for the MSP430. Thus we used a tool chain, shown at right, that converted the
      SPARK to C using SofCheck's AdaMagic compiler. We
      then compiled the C, along with the required low level drivers and libraries, to MSP430
      object code using Rowley Associates'
      CrossWorks.
      The primary Ada development was done using the GPS integrated development environment
      from AdaCore. GPS supports integration with SPARK
      and the GNAT Ada compiler was used for compiling and running tests. AdaMagic was only used
      to generate the final flight software via CrossWorks as described above.
     
    
      Software Metrics
      The SPARK portion of the flight control program consists of 5991 lines of code and 4095
      lines of comments (where 2843 comment lines are actually SPARK annotations), for a total
      of 10,086 lines. These numbers do not consider blank lines. The SPARK 2005
      Examiner found the code base free of flow errors but issued 72 warnings, mostly related to
      automatically generated loop assertions. The Examiner generated 4542 verification
      conditions (VCs) of which all but 102 were proved automatically. Thus 98% of all VCs were
      proved. In this project we attempted to prove the program free of runtime errors (to
      support our decision to suppress all checks) but we did not specifically attempt to prove
      any higher level properties of the program. Also due to lack of time before launch we did
      not pursue the remaining 102 unproved VCs either formally, for example with the checker
      tool, or via focused testing.
      The C portion of the flight control program consists of 2239 line (including
      blank lines). This does not include the header files or source files of the third party SD
      card library. Thus the C portion of the flight control program is approximately 18% of the
      total. However that number is somewhat inflated because the count of C source lines above
      includes blank lines.
      The final executable consumes 3874 bytes of RAM (not including stack space) and 45,428
      bytes of ROM. On our processor this corresponds to 47% of the RAM and 38% of the ROM.
      These numbers include the space consumed by the third party SD card library we used. No
      attempt was made, however, to analyze stack space consumption.