add the implementation of LP1768 wakeup based on the old WakeUp library
Dependencies: LPC1114_WakeInterruptIn
Fork of WakeUp by
WakeUp.cpp@0:fc439458a359, 2013-11-23 (annotated)
- Committer:
- Sissors
- Date:
- Sat Nov 23 11:35:14 2013 +0000
- Revision:
- 0:fc439458a359
v1.0
;
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
Sissors | 0:fc439458a359 | 1 | #include "WakeUp.h" |
Sissors | 0:fc439458a359 | 2 | |
Sissors | 0:fc439458a359 | 3 | FunctionPointer WakeUp::callback; |
Sissors | 0:fc439458a359 | 4 | float WakeUp::cycles_per_ms = 10.0; |
Sissors | 0:fc439458a359 | 5 | |
Sissors | 0:fc439458a359 | 6 | void WakeUp::set_ms(uint32_t ms) |
Sissors | 0:fc439458a359 | 7 | { |
Sissors | 0:fc439458a359 | 8 | //Enable clock to register interface: |
Sissors | 0:fc439458a359 | 9 | LPC_SYSCON->SYSAHBCLKCTRL |= 1<<9; |
Sissors | 0:fc439458a359 | 10 | |
Sissors | 0:fc439458a359 | 11 | //Clear the counter: |
Sissors | 0:fc439458a359 | 12 | LPC_WKT->CTRL |= 1<<2; |
Sissors | 0:fc439458a359 | 13 | if (ms != 0) { |
Sissors | 0:fc439458a359 | 14 | //Enable clock to register interface: |
Sissors | 0:fc439458a359 | 15 | LPC_SYSCON->SYSAHBCLKCTRL |= 1<<9; |
Sissors | 0:fc439458a359 | 16 | |
Sissors | 0:fc439458a359 | 17 | //Set 10kHz timer as source, and just to be sure clear status bit |
Sissors | 0:fc439458a359 | 18 | LPC_WKT->CTRL = 3; |
Sissors | 0:fc439458a359 | 19 | |
Sissors | 0:fc439458a359 | 20 | //Enable the 10kHz timer |
Sissors | 0:fc439458a359 | 21 | LPC_PMU->DPDCTRL |= (1<<2) | (1<<3); |
Sissors | 0:fc439458a359 | 22 | |
Sissors | 0:fc439458a359 | 23 | //Set interrupts |
Sissors | 0:fc439458a359 | 24 | NVIC_SetVector(WKT_IRQn, (uint32_t)WakeUp::irq_handler); |
Sissors | 0:fc439458a359 | 25 | NVIC_EnableIRQ(WKT_IRQn); |
Sissors | 0:fc439458a359 | 26 | |
Sissors | 0:fc439458a359 | 27 | //Load the timer |
Sissors | 0:fc439458a359 | 28 | LPC_WKT->COUNT = (uint32_t)((float)ms * cycles_per_ms); |
Sissors | 0:fc439458a359 | 29 | |
Sissors | 0:fc439458a359 | 30 | } else { |
Sissors | 0:fc439458a359 | 31 | //Disable clock to register interface: |
Sissors | 0:fc439458a359 | 32 | LPC_SYSCON->SYSAHBCLKCTRL &= ~(1<<9); |
Sissors | 0:fc439458a359 | 33 | |
Sissors | 0:fc439458a359 | 34 | //Disable the 10kHz timer |
Sissors | 0:fc439458a359 | 35 | LPC_PMU->DPDCTRL &= ~((1<<2) | (1<<3)); |
Sissors | 0:fc439458a359 | 36 | } |
Sissors | 0:fc439458a359 | 37 | } |
Sissors | 0:fc439458a359 | 38 | |
Sissors | 0:fc439458a359 | 39 | void WakeUp::irq_handler(void) |
Sissors | 0:fc439458a359 | 40 | { |
Sissors | 0:fc439458a359 | 41 | //Clear status |
Sissors | 0:fc439458a359 | 42 | LPC_WKT->CTRL |= 2; |
Sissors | 0:fc439458a359 | 43 | |
Sissors | 0:fc439458a359 | 44 | //Disable clock to register interface: |
Sissors | 0:fc439458a359 | 45 | LPC_SYSCON->SYSAHBCLKCTRL &= ~(1<<9); |
Sissors | 0:fc439458a359 | 46 | |
Sissors | 0:fc439458a359 | 47 | //Disable the 10kHz timer |
Sissors | 0:fc439458a359 | 48 | LPC_PMU->DPDCTRL &= ~((1<<2) | (1<<3)); |
Sissors | 0:fc439458a359 | 49 | |
Sissors | 0:fc439458a359 | 50 | callback.call(); |
Sissors | 0:fc439458a359 | 51 | } |
Sissors | 0:fc439458a359 | 52 | |
Sissors | 0:fc439458a359 | 53 | void WakeUp::calibrate(void) |
Sissors | 0:fc439458a359 | 54 | { |
Sissors | 0:fc439458a359 | 55 | cycles_per_ms = 10.0; |
Sissors | 0:fc439458a359 | 56 | set_ms(1100); |
Sissors | 0:fc439458a359 | 57 | wait_ms(100); |
Sissors | 0:fc439458a359 | 58 | |
Sissors | 0:fc439458a359 | 59 | uint32_t prevread = LPC_WKT->COUNT; |
Sissors | 0:fc439458a359 | 60 | uint32_t read = LPC_WKT->COUNT; |
Sissors | 0:fc439458a359 | 61 | while( read != prevread) { |
Sissors | 0:fc439458a359 | 62 | prevread = read; |
Sissors | 0:fc439458a359 | 63 | read = LPC_WKT->COUNT; |
Sissors | 0:fc439458a359 | 64 | } |
Sissors | 0:fc439458a359 | 65 | |
Sissors | 0:fc439458a359 | 66 | uint32_t ticks = 11000 - read; |
Sissors | 0:fc439458a359 | 67 | |
Sissors | 0:fc439458a359 | 68 | cycles_per_ms = ticks / 100.0; |
Sissors | 0:fc439458a359 | 69 | set_ms(0); |
Sissors | 0:fc439458a359 | 70 | } |
Sissors | 0:fc439458a359 | 71 | |
Sissors | 0:fc439458a359 | 72 |