2013-01-12 02:21:21 -04:00
|
|
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
2011-02-13 20:43:11 -04:00
|
|
|
/*
|
2012-08-17 03:21:25 -03:00
|
|
|
* Example of DataFlash library.
|
|
|
|
* Code by Jordi MuÒoz and Jose Julio. DIYDrones.com
|
|
|
|
*/
|
2011-02-13 20:43:11 -04:00
|
|
|
|
2011-07-19 20:00:18 -03:00
|
|
|
// Libraries
|
2012-10-04 10:46:35 -03:00
|
|
|
#include <AP_Common.h>
|
2012-12-12 18:21:04 -04:00
|
|
|
#include <AP_Param.h>
|
|
|
|
#include <AP_Progmem.h>
|
2012-10-04 10:46:35 -03:00
|
|
|
#include <AP_Math.h> // ArduPilot Mega Vector/Matrix math Library
|
2011-02-13 20:43:11 -04:00
|
|
|
#include <DataFlash.h>
|
|
|
|
|
2012-12-12 18:21:04 -04:00
|
|
|
#include <AP_HAL.h>
|
|
|
|
#include <AP_HAL_AVR.h>
|
|
|
|
|
2012-10-04 10:46:35 -03:00
|
|
|
|
2012-12-18 21:26:58 -04:00
|
|
|
const AP_HAL::HAL& hal = AP_HAL_BOARD_DRIVER;
|
|
|
|
|
2012-12-12 18:21:04 -04:00
|
|
|
#if CONFIG_HAL_BOARD == HAL_BOARD_APM2
|
|
|
|
DataFlash_APM2 DataFlash;
|
|
|
|
#elif CONFIG_HAL_BOARD == HAL_BOARD_APM1
|
|
|
|
DataFlash_APM1 DataFlash;
|
|
|
|
#endif
|
2012-01-09 00:26:56 -04:00
|
|
|
|
2013-01-12 02:21:21 -04:00
|
|
|
struct test_packet {
|
2013-01-12 07:16:32 -04:00
|
|
|
LOG_PACKET_HEADER;
|
2013-01-12 02:21:21 -04:00
|
|
|
uint16_t v1, v2, v3, v4;
|
|
|
|
int32_t l1, l2;
|
2013-01-12 07:16:32 -04:00
|
|
|
uint8_t dummy[80];
|
2013-01-12 02:21:21 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
#define NUM_PACKETS 20
|
2012-01-09 00:26:56 -04:00
|
|
|
|
2011-02-13 20:43:11 -04:00
|
|
|
void setup()
|
|
|
|
{
|
2012-08-17 03:21:25 -03:00
|
|
|
DataFlash.Init(); // DataFlash initialization
|
|
|
|
|
2012-12-12 18:21:04 -04:00
|
|
|
hal.console->println("Dataflash Log Test 1.0");
|
2012-08-17 03:21:25 -03:00
|
|
|
|
|
|
|
// Test
|
2012-12-12 18:21:04 -04:00
|
|
|
hal.scheduler->delay(20);
|
2012-08-17 03:21:25 -03:00
|
|
|
DataFlash.ReadManufacturerID();
|
2012-12-12 18:21:04 -04:00
|
|
|
hal.scheduler->delay(10);
|
2013-01-12 02:21:21 -04:00
|
|
|
hal.console->printf("Manufacturer: 0x%x Device: 0x%x PageSize: %u NumPages: %u\n",
|
|
|
|
(unsigned)DataFlash.df_manufacturer,
|
|
|
|
(unsigned)DataFlash.df_device,
|
|
|
|
(unsigned)DataFlash.df_PageSize,
|
|
|
|
(unsigned)DataFlash.df_NumPages);
|
|
|
|
|
|
|
|
if (DataFlash.NeedErase()) {
|
|
|
|
hal.console->println("Erasing...");
|
|
|
|
DataFlash.EraseAll();
|
|
|
|
}
|
2012-08-17 03:21:25 -03:00
|
|
|
|
|
|
|
// We start to write some info (sequentialy) starting from page 1
|
|
|
|
// This is similar to what we will do...
|
|
|
|
DataFlash.StartWrite(1);
|
2012-12-12 18:21:04 -04:00
|
|
|
hal.console->println("After testing perform erase before using DataFlash for logging!");
|
|
|
|
hal.console->println("");
|
|
|
|
hal.console->println("Writing to flash... wait...");
|
2013-01-12 02:21:21 -04:00
|
|
|
|
|
|
|
uint32_t total_micros = 0;
|
|
|
|
uint16_t i;
|
|
|
|
|
|
|
|
for (i = 0; i < NUM_PACKETS; i++) {
|
|
|
|
uint32_t start = hal.scheduler->micros();
|
|
|
|
// note that we use g++ style initialisers to make larger
|
|
|
|
// structures easier to follow
|
|
|
|
struct test_packet pkt = {
|
2013-01-12 07:16:32 -04:00
|
|
|
LOG_PACKET_HEADER_INIT(7),
|
2013-01-12 02:21:21 -04:00
|
|
|
v1 : 2000 + i,
|
|
|
|
v2 : 2001 + i,
|
|
|
|
v3 : 2002 + i,
|
|
|
|
v4 : 2003 + i,
|
|
|
|
l1 : (long)i * 5000,
|
2013-01-12 07:16:32 -04:00
|
|
|
l2 : (long)i * 16268
|
2013-01-12 02:21:21 -04:00
|
|
|
};
|
|
|
|
DataFlash.WriteBlock(&pkt, sizeof(pkt));
|
|
|
|
total_micros += hal.scheduler->micros() - start;
|
2013-01-12 07:16:32 -04:00
|
|
|
hal.scheduler->delay(20);
|
2012-08-17 03:21:25 -03:00
|
|
|
}
|
2013-01-12 02:21:21 -04:00
|
|
|
|
|
|
|
hal.console->printf("Average write time %.1f usec/byte\n",
|
|
|
|
(double)total_micros/((float)i*sizeof(struct test_packet)));
|
|
|
|
|
|
|
|
// ensure last page is written
|
|
|
|
DataFlash.FinishWrite();
|
|
|
|
|
2012-12-12 18:21:04 -04:00
|
|
|
hal.scheduler->delay(100);
|
2011-02-13 20:43:11 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void loop()
|
|
|
|
{
|
2013-01-12 02:21:21 -04:00
|
|
|
uint16_t i;
|
2012-08-17 03:21:25 -03:00
|
|
|
|
2012-12-12 18:21:04 -04:00
|
|
|
hal.console->println("Start reading page 1...");
|
2012-08-17 03:21:25 -03:00
|
|
|
|
|
|
|
DataFlash.StartRead(1); // We start reading from page 1
|
|
|
|
|
2013-01-12 02:21:21 -04:00
|
|
|
for (i = 0; i < NUM_PACKETS; i++) {
|
|
|
|
struct test_packet pkt;
|
|
|
|
DataFlash.ReadBlock(&pkt, sizeof(pkt));
|
2013-01-12 07:16:32 -04:00
|
|
|
hal.console->printf("PACKET: %02x,%02x,%02x,%u,%u,%u,%u,%ld,%ld\n",
|
2013-01-12 02:21:21 -04:00
|
|
|
(unsigned)pkt.head1,
|
|
|
|
(unsigned)pkt.head2,
|
2013-01-12 07:16:32 -04:00
|
|
|
(unsigned)pkt.msgid,
|
2013-01-12 02:21:21 -04:00
|
|
|
(unsigned)pkt.v1,
|
|
|
|
(unsigned)pkt.v2,
|
|
|
|
(unsigned)pkt.v3,
|
|
|
|
(unsigned)pkt.v4,
|
|
|
|
(long)pkt.l1,
|
2013-01-12 07:16:32 -04:00
|
|
|
(long)pkt.l2);
|
2012-08-17 03:21:25 -03:00
|
|
|
}
|
2013-01-12 02:21:21 -04:00
|
|
|
hal.console->printf("\nTest complete. Test will repeat in 20 seconds\n");
|
2012-12-12 18:21:04 -04:00
|
|
|
hal.scheduler->delay(20000);
|
2012-09-05 17:23:20 -03:00
|
|
|
}
|
2012-12-12 18:21:04 -04:00
|
|
|
|
|
|
|
AP_HAL_MAIN();
|