• FreeRTOS的application assignment


    Please follow the steps precisely in order to complete the objectives of the assignment. If you use the C++ FreeRTOS framework, it should make the assignment significantly easy.

    1. Create a producer task that takes 1 light sensor value every 1ms.
      • Collect the average of the 100 readings.
      • Write average value every 100ms (avg. of 100 samples) to the sensor queue.
      • Use medium priority for this task
    2. Create a consumer task that pulls the data off the sensor queue
      • Use infinite timeout value during queue receive API
      • Open a file (sensor.txt), and append the data to an output file on the SD card.
      • Save the data in this format: printf("%i, %i ", time, light)"
      • Just leave the file in "open" mode, such that it will flush the data after enough data is written rather than flushing it upon each write, which will consume a lot of CPU.
      • Use medium priority for this task
    3. At the end of the loop of each task, set a bit using FreeRTOS event group API.
      • At the end of each loop of the tasks, set a bit using the xEventGroupSetBits()
      • Task 1 should set bit1, Task 2 should set bit2 etc.
    4. Create a watchdog task that monitors the operation of the two tasks.
      • Use high priority for this task.
      • Every sixty seconds, save the CPU usage info to a file named "cpu.txt". See terminal command "infoHandler" for reference. Open the file, write the file, and close it immediately so the data is immediately flushed.
      • Use a timeout of 1 second, and wait for all the bits to set. If there are two tasks, wait for bit1, and bit2 etc.
      • If you fail to detect the bits are set, that means that the other tasks did not reach the end of the loop.
      • In the event of failed to detect the bits, append a file (stuck.txt) with the information about which task may be "stuck"
      • Open the file, append the data, and close the (stuck.txt) file to flush out the data immediately.
    5. Create a terminal command to "suspend" and "resume" a task by name.
      • "task suspend task1" should suspend a task named "task1"
      • "task resume task2" should suspend a task named "task2"
    6. Run the system, and under normal operation, you will see a file being saved with sensor data values.
      • Plot the file data in Excel to demonstrate.
    7. Suspend the producer task. The watchdog task should display a message and save relevant info to the SD card.
    8. Let the system run for a while, and note down the CPU usage in your text file.
    9. Change the ADC sensor implementation
      • Modify the source code of "adc.h" by not using ADC polling mode.
      • Instead of "trigger ADC", "wait for completion", and "read value", modify it to this:
        Upon ADC initialization, enable ADC interrupt, and create a binary semaphore.
        The ADC interrupt should "give" the semaphore upon completion of the ADC.
        Note that you need to read the ADC data register in order to clear the interrupt before you exit the ISR.
        After triggering the ADC, wait for ADC semaphore using xSemaphoreTake(), and then read the value.
    10. After changing the ADC behavior, let the system run for a while, and note down the CPU usage again.

    What you created is a "software watchdog". This means that in an event when a loop is stuck, or a task is frozen, you can save relevant information such that you can debug at a later time.

  • 相关阅读:
    自己写的DBHelper感慨颇深
    23种设计模式:观察者模式,第一次对观察者模式理解的这么通透。
    自己用心写的 存储过程分页 给自己的平台用
    开篇成长的开始[废话一把]
    C# 中i++在ref参数调用下的有趣现象
    点点滴滴的成长[2011111]:理解C#修饰符
    点点滴滴的成长[2011114]:自定义config文件
    扩展方法在Json字符串转化中的应用
    jquery学习二:jquery性能优化
    javascript系列1:函数
  • 原文地址:https://www.cnblogs.com/gpuasic/p/3758570.html
Copyright © 2020-2023  润新知