Dont cache dma buffers (#1110)

* add no_cache

* don't disable cache

* conventions

* formatting
This commit is contained in:
Matthew Kennedy 2020-01-28 21:32:43 -08:00 committed by GitHub
parent 4dd9edfcff
commit c51f3ad303
4 changed files with 10 additions and 18 deletions

View File

@ -77,8 +77,10 @@ typedef unsigned int time_t;
*/
#if defined(STM32F7XX)
#define CCM_RAM ".ram3"
#define NO_CACHE CCM_OPTIONAL
#else /* defined(STM32F4XX) */
#define CCM_RAM ".ram4"
#define NO_CACHE
#endif /* defined(STM32F4XX) */
#if EFI_USE_CCM

View File

@ -121,8 +121,8 @@ static void printError(const char *str, FRESULT f_error) {
scheduleMsg(&logger, "FATfs Error \"%s\" %d", str, f_error);
}
static FIL FDLogFile;
static FIL FDCurrFile;
static FIL FDLogFile NO_CACHE;
static FIL FDCurrFile NO_CACHE;
static int logFileIndex = 1;
static char logName[_MAX_FILLER + 20];

View File

@ -77,12 +77,9 @@ EXTERNC int getRemainingStack(thread_t *otp) {
void baseMCUInit(void) {
// looks like this holds a random value on start? Let's set a nice clean zero
DWT->CYCCNT = 0;
DWT->CYCCNT = 0;
BOR_Set(BOR_Level_1); // one step above default value
// open question if we need this or not
// SCB_DisableDCache();
}
void _unhandled_exception(void) {

View File

@ -29,12 +29,9 @@ EXTERN_ENGINE;
#include "pin_repository.h"
static Logging *logger;
/**
* We need to make sure we do not get F7 SPI DMA caching issues
* We also have "SCB_DisableDCache();" which is about the same since we need DMA SPI addressed not only for cj125
*/
static unsigned char tx_buff[2] CCM_OPTIONAL;
static unsigned char rx_buff[1] CCM_OPTIONAL;
static uint8_t tx_buff[2] NO_CACHE;
static uint8_t rx_buff[1] NO_CACHE;
static CJ125 globalInstance;
@ -83,15 +80,11 @@ static constexpr float lambdaLsu49[] = {
};
static int cjReadRegister(unsigned char regAddr) {
static uint8_t cjReadRegister(uint8_t regAddr) {
#if ! EFI_UNIT_TEST
spiSelect(driver);
tx_buff[0] = regAddr;
spiSend(driver, 1, tx_buff);
// safety?
chThdSleepMilliseconds(10);
rx_buff[0] = 0;
spiReceive(driver, 1, rx_buff);
spiUnselect(driver);
@ -104,7 +97,7 @@ static int cjReadRegister(unsigned char regAddr) {
#endif /* EFI_UNIT_TEST */
}
static void cjWriteRegister(unsigned char regAddr, unsigned char regValue) {
static void cjWriteRegister(uint8_t regAddr, uint8_t regValue) {
tx_buff[0] = regAddr;
tx_buff[1] = regValue;
#ifdef CJ125_DEBUG_SPI