mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
DataFlash: don't try and open logfile on failure more than once
this prevents a corrupted microSD card from causing a continuous attempt to open a log file while in flight, which can cause large scheduler delays Pair-Programmed-With: Grant Morphett <grant@gmorph.com>
This commit is contained in:
parent
60ded486c2
commit
0c371f1b98
@ -39,6 +39,7 @@ DataFlash_File::DataFlash_File(const char *log_directory) :
|
|||||||
_read_offset(0),
|
_read_offset(0),
|
||||||
_write_offset(0),
|
_write_offset(0),
|
||||||
_initialised(false),
|
_initialised(false),
|
||||||
|
_open_error(false),
|
||||||
_log_directory(log_directory),
|
_log_directory(log_directory),
|
||||||
_writebuf(NULL),
|
_writebuf(NULL),
|
||||||
_writebuf_size(16*1024),
|
_writebuf_size(16*1024),
|
||||||
@ -128,7 +129,7 @@ void DataFlash_File::Init(const struct LogStructure *structure, uint8_t num_type
|
|||||||
// return true for CardInserted() if we successfully initialised
|
// return true for CardInserted() if we successfully initialised
|
||||||
bool DataFlash_File::CardInserted(void)
|
bool DataFlash_File::CardInserted(void)
|
||||||
{
|
{
|
||||||
return _initialised;
|
return _initialised && !_open_error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -195,7 +196,7 @@ void DataFlash_File::EraseAll()
|
|||||||
/* Write a block of data at current offset */
|
/* Write a block of data at current offset */
|
||||||
void DataFlash_File::WriteBlock(const void *pBuffer, uint16_t size)
|
void DataFlash_File::WriteBlock(const void *pBuffer, uint16_t size)
|
||||||
{
|
{
|
||||||
if (_write_fd == -1 || !_initialised || !_writes_enabled) {
|
if (_write_fd == -1 || !_initialised || _open_error || !_writes_enabled) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
uint16_t _head;
|
uint16_t _head;
|
||||||
@ -232,7 +233,7 @@ void DataFlash_File::WriteBlock(const void *pBuffer, uint16_t size)
|
|||||||
*/
|
*/
|
||||||
void DataFlash_File::ReadBlock(void *pkt, uint16_t size)
|
void DataFlash_File::ReadBlock(void *pkt, uint16_t size)
|
||||||
{
|
{
|
||||||
if (_read_fd == -1 || !_initialised) {
|
if (_read_fd == -1 || !_initialised || _open_error) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -311,7 +312,7 @@ void DataFlash_File::get_log_boundaries(uint16_t log_num, uint16_t & start_page,
|
|||||||
*/
|
*/
|
||||||
int16_t DataFlash_File::get_log_data(uint16_t log_num, uint16_t page, uint32_t offset, uint16_t len, uint8_t *data)
|
int16_t DataFlash_File::get_log_data(uint16_t log_num, uint16_t page, uint32_t offset, uint16_t len, uint8_t *data)
|
||||||
{
|
{
|
||||||
if (!_initialised) {
|
if (!_initialised || _open_error) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (_read_fd != -1 && log_num != _read_fd_log_num) {
|
if (_read_fd != -1 && log_num != _read_fd_log_num) {
|
||||||
@ -325,10 +326,17 @@ int16_t DataFlash_File::get_log_data(uint16_t log_num, uint16_t page, uint32_t o
|
|||||||
}
|
}
|
||||||
stop_logging();
|
stop_logging();
|
||||||
_read_fd = ::open(fname, O_RDONLY);
|
_read_fd = ::open(fname, O_RDONLY);
|
||||||
free(fname);
|
|
||||||
if (_read_fd == -1) {
|
if (_read_fd == -1) {
|
||||||
|
_open_error = true;
|
||||||
|
int saved_errno = errno;
|
||||||
|
::printf("Log read open fail for %s - %s\n",
|
||||||
|
fname, strerror(saved_errno));
|
||||||
|
hal.console->printf("Log read open fail for %s - %s\n",
|
||||||
|
fname, strerror(saved_errno));
|
||||||
|
free(fname);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
free(fname);
|
||||||
_read_offset = 0;
|
_read_offset = 0;
|
||||||
_read_fd_log_num = log_num;
|
_read_fd_log_num = log_num;
|
||||||
}
|
}
|
||||||
@ -408,6 +416,12 @@ uint16_t DataFlash_File::start_new_log(void)
|
|||||||
{
|
{
|
||||||
stop_logging();
|
stop_logging();
|
||||||
|
|
||||||
|
if (_open_error) {
|
||||||
|
// we have previously failed to open a file - don't try again
|
||||||
|
// to prevent us trying to open files while in flight
|
||||||
|
return 0xFFFF;
|
||||||
|
}
|
||||||
|
|
||||||
if (_read_fd != -1) {
|
if (_read_fd != -1) {
|
||||||
::close(_read_fd);
|
::close(_read_fd);
|
||||||
_read_fd = -1;
|
_read_fd = -1;
|
||||||
@ -423,11 +437,18 @@ uint16_t DataFlash_File::start_new_log(void)
|
|||||||
}
|
}
|
||||||
char *fname = _log_file_name(log_num);
|
char *fname = _log_file_name(log_num);
|
||||||
_write_fd = ::open(fname, O_WRONLY|O_CREAT|O_TRUNC, 0666);
|
_write_fd = ::open(fname, O_WRONLY|O_CREAT|O_TRUNC, 0666);
|
||||||
free(fname);
|
|
||||||
if (_write_fd == -1) {
|
if (_write_fd == -1) {
|
||||||
_initialised = false;
|
_initialised = false;
|
||||||
|
_open_error = true;
|
||||||
|
int saved_errno = errno;
|
||||||
|
::printf("Log open fail for %s - %s\n",
|
||||||
|
fname, strerror(saved_errno));
|
||||||
|
hal.console->printf("Log open fail for %s - %s\n",
|
||||||
|
fname, strerror(saved_errno));
|
||||||
|
free(fname);
|
||||||
return 0xFFFF;
|
return 0xFFFF;
|
||||||
}
|
}
|
||||||
|
free(fname);
|
||||||
_write_offset = 0;
|
_write_offset = 0;
|
||||||
_writebuf_head = 0;
|
_writebuf_head = 0;
|
||||||
_writebuf_tail = 0;
|
_writebuf_tail = 0;
|
||||||
@ -452,7 +473,7 @@ void DataFlash_File::LogReadProcess(uint16_t log_num,
|
|||||||
AP_HAL::BetterStream *port)
|
AP_HAL::BetterStream *port)
|
||||||
{
|
{
|
||||||
uint8_t log_step = 0;
|
uint8_t log_step = 0;
|
||||||
if (!_initialised) {
|
if (!_initialised || _open_error) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (_read_fd != -1) {
|
if (_read_fd != -1) {
|
||||||
@ -584,7 +605,7 @@ void DataFlash_File::ListAvailableLogs(AP_HAL::BetterStream *port)
|
|||||||
void DataFlash_File::_io_timer(void)
|
void DataFlash_File::_io_timer(void)
|
||||||
{
|
{
|
||||||
uint16_t _tail;
|
uint16_t _tail;
|
||||||
if (_write_fd == -1 || !_initialised) {
|
if (_write_fd == -1 || !_initialised || _open_error) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -58,6 +58,7 @@ private:
|
|||||||
uint32_t _read_offset;
|
uint32_t _read_offset;
|
||||||
uint32_t _write_offset;
|
uint32_t _write_offset;
|
||||||
volatile bool _initialised;
|
volatile bool _initialised;
|
||||||
|
volatile bool _open_error;
|
||||||
const char *_log_directory;
|
const char *_log_directory;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user