2012-12-18 20:09:24 -04:00
|
|
|
|
|
|
|
#ifndef __AP_HAL_UTIL_H__
|
|
|
|
#define __AP_HAL_UTIL_H__
|
|
|
|
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include "AP_HAL_Namespace.h"
|
|
|
|
#include <AP_Progmem.h>
|
|
|
|
|
|
|
|
class AP_HAL::Util {
|
|
|
|
public:
|
2015-01-28 19:15:48 -04:00
|
|
|
// soft_armed starts out true
|
|
|
|
Util() : soft_armed(true) {}
|
|
|
|
|
2013-09-21 00:28:46 -03:00
|
|
|
int snprintf(char* str, size_t size,
|
|
|
|
const char *format, ...);
|
2012-12-18 20:09:24 -04:00
|
|
|
|
2013-09-21 00:28:46 -03:00
|
|
|
int snprintf_P(char* str, size_t size,
|
|
|
|
const prog_char_t *format, ...);
|
2012-12-18 20:09:24 -04:00
|
|
|
|
2013-09-21 00:28:46 -03:00
|
|
|
int vsnprintf(char* str, size_t size,
|
|
|
|
const char *format, va_list ap);
|
2012-12-18 20:09:24 -04:00
|
|
|
|
2013-09-21 00:28:46 -03:00
|
|
|
int vsnprintf_P(char* str, size_t size,
|
|
|
|
const prog_char_t *format, va_list ap);
|
2012-12-18 20:09:24 -04:00
|
|
|
|
2015-01-28 19:15:48 -04:00
|
|
|
void set_soft_armed(const bool b) { soft_armed = b; }
|
|
|
|
bool get_soft_armed() const { return soft_armed; }
|
|
|
|
|
2015-06-28 16:09:20 -03:00
|
|
|
virtual const char* get_custom_log_directory() { return NULL; }
|
|
|
|
virtual const char* get_custom_terrain_directory() const { return NULL; }
|
|
|
|
|
2013-02-07 00:03:34 -04:00
|
|
|
// run a debug shall on the given stream if possible. This is used
|
|
|
|
// to support dropping into a debug shell to run firmware upgrade
|
|
|
|
// commands
|
|
|
|
virtual bool run_debug_shell(AP_HAL::BetterStream *stream) = 0;
|
|
|
|
|
2013-10-05 02:46:35 -03:00
|
|
|
enum safety_state {
|
|
|
|
SAFETY_NONE, SAFETY_DISARMED, SAFETY_ARMED
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
return state of safety switch, if applicable
|
|
|
|
*/
|
|
|
|
virtual enum safety_state safety_switch_state(void) { return SAFETY_NONE; }
|
2013-10-23 09:26:36 -03:00
|
|
|
|
|
|
|
/*
|
|
|
|
set system clock in UTC microseconds
|
|
|
|
*/
|
|
|
|
virtual void set_system_clock(uint64_t time_utc_usec) {}
|
2013-11-25 20:57:40 -04:00
|
|
|
|
|
|
|
/*
|
|
|
|
get system identifier (eg. serial number)
|
|
|
|
return false if a system identifier is not available
|
|
|
|
|
|
|
|
Buf should be filled with a printable string and must be null
|
|
|
|
terminated
|
|
|
|
*/
|
|
|
|
virtual bool get_system_id(char buf[40]) { return false; }
|
2013-12-27 23:51:01 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
how much free memory do we have in bytes. If more than 0xFFFF
|
|
|
|
then return 0xFFFF. If unknown return 4096
|
|
|
|
*/
|
|
|
|
virtual uint16_t available_memory(void) { return 4096; }
|
2014-02-22 17:15:39 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
return commandline arguments, if available
|
|
|
|
*/
|
|
|
|
virtual void commandline_arguments(uint8_t &argc, char * const *&argv) { argc = 0; }
|
2014-08-23 04:56:24 -03:00
|
|
|
|
|
|
|
/*
|
|
|
|
ToneAlarm Driver
|
|
|
|
*/
|
2014-11-15 01:50:07 -04:00
|
|
|
virtual bool toneAlarm_init() { return false;}
|
2014-08-23 04:56:24 -03:00
|
|
|
virtual void toneAlarm_set_tune(uint8_t tune) {}
|
|
|
|
virtual void _toneAlarm_timer_tick() {}
|
2015-01-28 19:15:48 -04:00
|
|
|
|
2015-06-17 04:04:15 -03:00
|
|
|
/*
|
|
|
|
return a stream for access to a system shell, if available
|
|
|
|
*/
|
|
|
|
virtual AP_HAL::Stream *get_shell_stream() { return NULL; }
|
|
|
|
|
2015-01-28 19:15:48 -04:00
|
|
|
protected:
|
|
|
|
bool soft_armed;
|
2012-12-18 20:09:24 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // __AP_HAL_UTIL_H__
|
|
|
|
|