diff options
author | Clyne Sullivan <clyne@bitgloo.com> | 2021-01-25 18:13:51 -0500 |
---|---|---|
committer | Clyne Sullivan <clyne@bitgloo.com> | 2021-01-25 18:13:51 -0500 |
commit | 1a14ef827ed99a814b00d8ea4b98b8633582b945 (patch) | |
tree | 215b73e0b2cf5e22e2348ce72134ad64629ff7ae /source | |
parent | e132d52adf52b91cc44741c9d13c178219d7a5f5 (diff) |
fix trig funcs; idle sleep w/ button to wake for debug
Diffstat (limited to 'source')
-rw-r--r-- | source/cordic.cpp | 62 | ||||
-rw-r--r-- | source/main.cpp | 14 |
2 files changed, 49 insertions, 27 deletions
diff --git a/source/cordic.cpp b/source/cordic.cpp index 2a44015..4852563 100644 --- a/source/cordic.cpp +++ b/source/cordic.cpp @@ -12,71 +12,79 @@ static void prepare() { while (CORDIC->CSR & CORDIC_CSR_RRDY) asm("mov r0, %0" :: "r" (CORDIC->RDATA)); } -static uint32_t dtoq(double in) { - double res = in * 0x7FFFFFFF; - int32_t resi = res; - return resi; + +static uint32_t dtoq(double) { + uint32_t res; + asm("vcvt.s32.f64 d0, d0, #31;" + "vmov %0, r5, d0" + : "=r" (res)); + return res; } -static double qtod(uint32_t in) { - int32_t ini = in; - double res = ini; - return res / 0x7FFFFFFF; +__attribute__((naked)) +static double qtod(uint32_t) { + asm("eor r1, r1;" + "vmov d0, r0, r1;" + "vcvt.f64.s32 d0, d0, #31;" + "bx lr"); + return 0; } - __attribute__((naked)) -double mod(double n, double) { +double mod(double, double) { asm("vdiv.f64 d2, d0, d1;" "vrintz.f64 d2;" "vmul.f64 d1, d1, d2;" "vsub.f64 d0, d0, d1;" "bx lr"); - return n; + return 0; } double cos(double x) { - x = (mod(x, 2 * math::PI) - math::PI) / math::PI; + x = mod(x, 2 * math::PI) / math::PI; + auto input = dtoq(x > 1. ? x - 2 : x); + prepare(); CORDIC->CSR = CORDIC_CSR_NARGS | CORDIC_CSR_NRES | (6 << CORDIC_CSR_PRECISION_Pos) | (0 << CORDIC_CSR_FUNC_Pos); - auto in = dtoq(x); - CORDIC->WDATA = in; - CORDIC->WDATA = in & 0x7FFFFFFF; + CORDIC->WDATA = input; + CORDIC->WDATA = input; while (!(CORDIC->CSR & CORDIC_CSR_RRDY)); double cosx = qtod(CORDIC->RDATA) / x; - in = CORDIC->RDATA; + [[maybe_unused]] auto sinx = CORDIC->RDATA; return cosx; } double sin(double x) { - x = (mod(x, 2 * math::PI) - math::PI) / math::PI; + x = mod(x, 2 * math::PI) / math::PI; + auto input = dtoq(x > 1. ? x - 2 : x); + prepare(); CORDIC->CSR = CORDIC_CSR_NARGS | CORDIC_CSR_NRES | (6 << CORDIC_CSR_PRECISION_Pos) | (1 << CORDIC_CSR_FUNC_Pos); - auto in = dtoq(x); - CORDIC->WDATA = in; - CORDIC->WDATA = in & 0x7FFFFFFF; + CORDIC->WDATA = input; + CORDIC->WDATA = input; while (!(CORDIC->CSR & CORDIC_CSR_RRDY)); double sinx = qtod(CORDIC->RDATA) / x; - in = CORDIC->RDATA; + [[maybe_unused]] auto cosx = CORDIC->RDATA; return sinx; } double tan(double x) { - x = (mod(x, 2 * math::PI) - math::PI) / math::PI; + x = mod(x, 2 * math::PI) / math::PI; + auto input = dtoq(x > 1. ? x - 2 : x); + prepare(); CORDIC->CSR = CORDIC_CSR_NARGS | CORDIC_CSR_NRES | (6 << CORDIC_CSR_PRECISION_Pos) | (1 << CORDIC_CSR_FUNC_Pos); - auto in = dtoq(x); - CORDIC->WDATA = in; - CORDIC->WDATA = in & 0x7FFFFFFF; + CORDIC->WDATA = input; + CORDIC->WDATA = input; while (!(CORDIC->CSR & CORDIC_CSR_RRDY)); double sinx = qtod(CORDIC->RDATA) / x; @@ -85,9 +93,9 @@ double tan(double x) { } __attribute__((naked)) -double sqrt(double x) { +double sqrt(double) { asm("vsqrt.f64 d0, d0; bx lr"); - return x; + return 0.; } } diff --git a/source/main.cpp b/source/main.cpp index a682cfe..97612f4 100644 --- a/source/main.cpp +++ b/source/main.cpp @@ -75,6 +75,8 @@ int main() halInit(); chSysInit(); + palSetLineMode(LINE_BUTTON, PAL_MODE_INPUT); + // Enable FPU SCB->CPACR |= 0xF << 20; @@ -353,6 +355,18 @@ THD_FUNCTION(Thread1, arg) palClearLine(led); chThdSleepMilliseconds(delay); + if (run_status == RunStatus::Idle && palReadLine(LINE_BUTTON)) { + palSetLine(LINE_LED_RED); + palSetLine(LINE_LED_YELLOW); + asm("cpsid i"); + while (!palReadLine(LINE_BUTTON)) + asm("nop"); + asm("cpsie i"); + palClearLine(LINE_LED_RED); + palClearLine(LINE_LED_YELLOW); + chThdSleepMilliseconds(500); + } + if (auto err = EM.hasError(); err ^ erroron) { erroron = err; if (err) |