mirror of
git://projects.qi-hardware.com/antorcha.git
synced 2024-11-01 13:15:55 +02:00
whirl/fw/: design testing: acceleration sensor
Switch selects display move: N = counter, E = WE axis; S = NS axis; SW = hold
This commit is contained in:
parent
fd3494004e
commit
9a4fd0f524
@ -1,3 +1,4 @@
|
|||||||
|
#include <stdbool.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
#define F_CPU 8000000UL
|
#define F_CPU 8000000UL
|
||||||
@ -45,8 +46,41 @@ static void send(uint16_t pattern)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline void admux(bool x)
|
||||||
|
{
|
||||||
|
ADMUX =
|
||||||
|
1 << REFS0 | /* Vref is AVcc */
|
||||||
|
(x ? ADC_X : ADC_Y);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline void adcsra(bool start)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* The ADC needs to run at clkADC <= 200 kHz for full resolution.
|
||||||
|
* At clkADC = 125 kHz, a conversion takes about 110 us.
|
||||||
|
*/
|
||||||
|
ADCSRA =
|
||||||
|
1 << ADEN | /* enable ADC */
|
||||||
|
(start ? 1 << ADSC : 0) |
|
||||||
|
1 << ADIE | /* enable ADC interrupts */
|
||||||
|
6; /* clkADC = clk/64 -> 125 kHz */
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static uint16_t adc(bool x)
|
||||||
|
{
|
||||||
|
adcsra(0);
|
||||||
|
admux(x);
|
||||||
|
adcsra(1);
|
||||||
|
while (ADCSRA & (1 << ADSC));
|
||||||
|
return ADC;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
|
uint8_t mode = 0;
|
||||||
uint16_t n = 0;
|
uint16_t n = 0;
|
||||||
|
|
||||||
PORTB = HIGH(B);
|
PORTB = HIGH(B);
|
||||||
@ -68,8 +102,23 @@ int main(void)
|
|||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
while (!PIN(SW_SW));
|
while (!PIN(SW_SW));
|
||||||
|
if (!PIN(SW_N))
|
||||||
|
mode = 0;
|
||||||
|
if (!PIN(SW_E))
|
||||||
|
mode = 1;
|
||||||
|
if (!PIN(SW_S))
|
||||||
|
mode = 2;
|
||||||
|
switch (mode) {
|
||||||
|
case 1:
|
||||||
|
send(adc(0));
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
send(adc(1));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
send(n);
|
send(n);
|
||||||
n++;
|
n++;
|
||||||
|
}
|
||||||
// _delay_ms(100);
|
// _delay_ms(100);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user