2015-07-10 06:01:56 -07:00
|
|
|
/**
|
2019-07-06 17:15:49 -07:00
|
|
|
* @file os_util.c
|
|
|
|
* @brief Utility methods related to operating system usage
|
2015-07-10 06:01:56 -07:00
|
|
|
*
|
|
|
|
* @date Nov 15, 2012
|
2019-07-06 17:15:49 -07:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2019
|
2015-07-10 06:01:56 -07:00
|
|
|
*
|
|
|
|
* This file is part of rusEfi - see http://rusefi.com
|
|
|
|
*
|
|
|
|
* rusEfi is free software; you can redistribute it and/or modify it under the terms of
|
|
|
|
* the GNU General Public License as published by the Free Software Foundation; either
|
|
|
|
* version 3 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* rusEfi is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
|
|
|
|
* even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along with this program.
|
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2018-09-16 19:39:46 -07:00
|
|
|
#include "global.h"
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2016-02-11 14:03:09 -08:00
|
|
|
#if !EFI_UNIT_TEST
|
2019-07-03 18:01:48 -07:00
|
|
|
#include "os_access.h"
|
2019-07-06 17:15:49 -07:00
|
|
|
#include "os_util.h"
|
2016-02-11 14:03:09 -08:00
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
void chVTSetAny(virtual_timer_t *vtp, systime_t time, vtfunc_t vtfunc, void *par) {
|
|
|
|
bool wasLocked = lockAnyContext();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* todo: this could be simplified once we migrate to ChibiOS 3.0
|
|
|
|
* See http://www.chibios.org/dokuwiki/doku.php?id=chibios:howtos:porting_from_2_to_3
|
|
|
|
*/
|
|
|
|
if (chVTIsArmedI(vtp)) {
|
|
|
|
chVTResetI(vtp);
|
|
|
|
}
|
|
|
|
|
|
|
|
chVTSetI(vtp, time, vtfunc, par);
|
|
|
|
if (!wasLocked) {
|
|
|
|
unlockAnyContext();
|
|
|
|
}
|
|
|
|
}
|
2016-02-11 14:03:09 -08:00
|
|
|
|
2019-03-29 07:29:01 -07:00
|
|
|
/**
|
|
|
|
* @return TRUE if already in locked context
|
2019-08-11 12:23:15 -07:00
|
|
|
* TODO: refactor to new 'syssts_t sts = chSysGetStatusAndLockX();' pattern
|
2019-03-29 07:29:01 -07:00
|
|
|
*/
|
|
|
|
bool lockAnyContext(void) {
|
|
|
|
int alreadyLocked = isLocked();
|
|
|
|
if (alreadyLocked)
|
|
|
|
return true;
|
|
|
|
#if USE_PORT_LOCK
|
|
|
|
port_lock();
|
|
|
|
#else /* #if USE_PORT_LOCK */
|
|
|
|
if (isIsrContext()) {
|
|
|
|
chSysLockFromISR()
|
|
|
|
;
|
|
|
|
} else {
|
|
|
|
chSysLock()
|
|
|
|
;
|
|
|
|
}
|
|
|
|
#endif /* #if USE_PORT_LOCK */
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2019-08-11 12:23:15 -07:00
|
|
|
/**
|
|
|
|
* TODO: refactor to new 'chSysRestoreStatusX(sts);' pattern
|
|
|
|
*/
|
2019-03-29 07:29:01 -07:00
|
|
|
void unlockAnyContext(void) {
|
|
|
|
#if USE_PORT_LOCK
|
|
|
|
port_unlock();
|
|
|
|
#else /* #if USE_PORT_LOCK */
|
|
|
|
if (isIsrContext()) {
|
|
|
|
chSysUnlockFromISR()
|
|
|
|
;
|
|
|
|
} else {
|
|
|
|
chSysUnlock()
|
|
|
|
;
|
|
|
|
}
|
|
|
|
#endif /* #if USE_PORT_LOCK */
|
|
|
|
}
|
|
|
|
|
2019-03-31 14:44:34 -07:00
|
|
|
#endif /* EFI_UNIT_TEST */
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* See also getRemainingStack()
|
|
|
|
*/
|
|
|
|
int getMaxUsedStack(uint8_t *ptr, int size) {
|
|
|
|
/**
|
|
|
|
* maximum used stack size total stack buffer size minus position of first modified byte
|
|
|
|
*/
|
|
|
|
#if ! EFI_UNIT_TEST
|
|
|
|
for (int i = 0; i < size; i++) {
|
|
|
|
if (ptr[i] != CH_DBG_STACK_FILL_VALUE) {
|
|
|
|
return size - i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* EFI_UNIT_TEST */
|
|
|
|
return 0;
|
|
|
|
}
|
2019-03-29 07:29:01 -07:00
|
|
|
|