2012-09-07 15:41:54 -03:00
|
|
|
|
|
|
|
#include <AP_Common.h>
|
2012-10-27 00:55:17 -03:00
|
|
|
#include <AP_Progmem.h>
|
2012-09-07 15:41:54 -03:00
|
|
|
#include <AP_HAL.h>
|
|
|
|
#include <AP_HAL_AVR.h>
|
|
|
|
|
|
|
|
const AP_HAL::HAL& hal = AP_HAL_AVR_APM1;
|
|
|
|
|
|
|
|
uint8_t fibs[12] = { 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144 };
|
|
|
|
|
|
|
|
void test_erase() {
|
2012-10-26 21:26:19 -03:00
|
|
|
hal.console->printf_P(PSTR("erasing... "));
|
2012-09-07 15:41:54 -03:00
|
|
|
for(int i = 0; i < 100; i++) {
|
2012-11-12 15:05:20 -04:00
|
|
|
hal.storage->write_byte(i, 0);
|
2012-09-07 15:41:54 -03:00
|
|
|
}
|
2012-10-26 21:26:19 -03:00
|
|
|
hal.console->printf_P(PSTR(" done.\r\n"));
|
2012-09-07 15:41:54 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
void test_write() {
|
2012-10-26 21:26:19 -03:00
|
|
|
hal.console->printf_P(PSTR("writing... "));
|
2012-11-12 15:05:20 -04:00
|
|
|
hal.storage->write_block(0, fibs, 12);
|
2012-10-26 21:26:19 -03:00
|
|
|
hal.console->printf_P(PSTR(" done.\r\n"));
|
2012-09-07 15:41:54 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
void test_readback() {
|
2012-10-26 21:26:19 -03:00
|
|
|
hal.console->printf_P(PSTR("reading back...\r\n"));
|
2012-09-07 15:41:54 -03:00
|
|
|
uint8_t readback[12];
|
|
|
|
bool success = true;
|
2012-11-12 15:05:20 -04:00
|
|
|
hal.storage->read_block(readback, 0, 12);
|
2012-09-07 15:41:54 -03:00
|
|
|
for (int i = 0; i < 12; i++) {
|
|
|
|
if (readback[i] != fibs[i]) {
|
|
|
|
success = false;
|
2012-10-26 21:26:19 -03:00
|
|
|
hal.console->printf_P(PSTR("At index %d expected %d got %d\r\n"),
|
2012-09-07 15:41:54 -03:00
|
|
|
i, (int) fibs[i], (int) readback[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (success) {
|
2012-10-26 21:26:19 -03:00
|
|
|
hal.console->printf_P(PSTR("all bytes read successfully\r\n"));
|
2012-09-07 15:41:54 -03:00
|
|
|
}
|
2012-10-26 21:26:19 -03:00
|
|
|
hal.console->printf_P(PSTR("done reading back.\r\n"));
|
2012-09-07 15:41:54 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
void setup (void) {
|
2012-10-26 21:26:19 -03:00
|
|
|
hal.console->printf_P(PSTR("Starting AP_HAL_AVR::Storage test\r\n"));
|
2012-09-07 15:41:54 -03:00
|
|
|
test_erase();
|
|
|
|
test_write();
|
|
|
|
test_readback();
|
|
|
|
}
|
|
|
|
|
|
|
|
void loop (void) { }
|
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
int main (void) {
|
|
|
|
hal.init(NULL);
|
|
|
|
setup();
|
|
|
|
for(;;) loop();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|