Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

View file
nameFW 101 - S22F23.pptx

Introduction

Welcome to the firmware team! We’re glad to have you.

In this lesson we’ll be covering:

  1. What firmware is

  2. An overview of our firmware system

  3. How we’re working remotely

  4. What our process for writing firmware is

Just a quick note before we jump into the content. All of our modules assume that you have some familiarity with programming, specifically the C language. You unfortunately won’t be able to do much until you have some familiarity with the language (specifically pointers, functions and structures).

...

Each non-bolded line in the diagram represents a firmware project that controls a part of the car’s electrical system, grouped under the headings in bold. Here’s a quick rundown of what each firmware project does:

  1. Battery: Ensures the battery doesn’t explode.

  2. Driver controls: Takes input from the driver and passes it on to the rest of the system.

  3. Power distribution: Turns other boards on and off (controls which boards are powered).

  4. Drivetrain: Converts the angle that the pedal is at to the current levels for the motors (so if you floor it the car will go faster).

  5. Charging: Manages charging of the battery from an off-the-shelf wall electric car wall charger or from the solar array.

Your PC vs a Microcontroller

...

Our firmware runs in safety critical situations, and as such it can be dangerous if it goes wrong. To help prevent this we have a structure for creating and testing our firmware.

  1. High-level design: We come up with a high-level structure of the project that fulfils the requirement.

  2. Detail design: we sort out the specifics, like what events or messages need to be passed between modules of the project

  3. Implementation: we write the code.

  4. Unit testing: we write tests that test specific parts of the code to make sure our logic works the way we think it does.

  5. IO testing/Hardware validation: input/output testing. We run the project on hardware, and make sure the hardware works the way we expect it to.

  6. Integration testing: we connect multiple boards together and make sure they work together the way we expect them to.

Notice how much testing we go through! This is really important. In firmware, writing the code is often only half the battle, and there can be many unforeseen delays when you actually start interacting with hardware.

...

Thanks for sticking through! In conclusion, here’s what you should come away from reading this with an understanding of:

  1. What firmware is

  2. What our firmware systems do at a high level

  3. How we’re able to work on firmware without direct access to the hardware

  4. Our process for completing firmware projects

Next in firmware 102, we’ll go into more depth on our firmware system, controller boards, our project structure, testing and validation, and our collaboration platforms. We hope to see you there!

...

There are several tasks that need to be completed as part of this module:

  1. Learn about Git and the Command Line by watching/reading the following tutorials

    1. Git Tutorial Videos (part 1 and 2) and branching lesson

    2. Command Line Tutorials (Part 1 and 2)

  2. Get your environment set up by following the instructions listed at Setup

  3. Write your very own Hello World program!

1. Intro Videos

These videos give an introduction to two of the main tools we use on our team, Git and the shell command line. We suggest watching them if you aren’t very experienced in one or the other, since the rest of the onboarding content will rely heavily on these concepts. However, we also do explain it as we go, so feel free to continue on even if you still haven’t fully grasped the concepts, and use these resources when you get stuck.

...

You will need to use a few things from our code base for this project.

  1. Include the “log.h” library. We have our own version of printf which allows us to safely print to the console. You can use it the exact same way as printf, just replacing it with LOG_DEBUG, ie:
    LOG_DEBUG("Hello World %d\n", my_int);

Run the program using the scons command from above (with a different project name).This program should run forever in a while true loop.

...