Code optimized, delay changing via USB added and animation viewing
routine fixed.
This commit is contained in:
parent
5d944fac4b
commit
73ad4d9fd9
4 changed files with 24 additions and 20 deletions
|
@ -18,7 +18,8 @@ main()
|
||||||
init();
|
init();
|
||||||
init_usb();
|
init_usb();
|
||||||
|
|
||||||
frame = 0x07ffffff;
|
//frame = 0x07ffffff;
|
||||||
|
mode = 2;
|
||||||
|
|
||||||
// Hauptschleife
|
// Hauptschleife
|
||||||
for (;;)
|
for (;;)
|
||||||
|
@ -31,11 +32,11 @@ main()
|
||||||
void init()
|
void init()
|
||||||
{
|
{
|
||||||
// Ports vorbereiten
|
// Ports vorbereiten
|
||||||
DDRB = 0b11111111; // PB0-PB7: LED 1-8 (Kathoden)
|
DDRB = 0b11111111; // PB0-PB7: LED 1-8 (Kathoden)
|
||||||
PORTB = 0b11111111; // HIGH
|
PORTB = 0b11111111; // HIGH
|
||||||
|
|
||||||
DDRD = 0b01111000; // PD6: LED 9 (Kathode); PD5-PD3: A-C (Anoden)
|
DDRD = 0b01111000; // PD6: LED 9 (Kathode); PD5-PD3: A-C (Anoden)
|
||||||
PORTD = 0b01000000;
|
PORTD = 0b01000000;
|
||||||
|
|
||||||
// Timer-Interrupt "TIMER1" vorbereiten
|
// Timer-Interrupt "TIMER1" vorbereiten
|
||||||
|
|
||||||
|
@ -67,14 +68,17 @@ ISR (TIMER1_COMPA_vect)
|
||||||
{
|
{
|
||||||
if (frmnum == 32)
|
if (frmnum == 32)
|
||||||
{
|
{
|
||||||
if (mode > 0)
|
|
||||||
frmnum = 0;
|
|
||||||
if (mode == 1)
|
if (mode == 1)
|
||||||
mode = 0;
|
mode = 0;
|
||||||
} else
|
frmnum = 0;
|
||||||
setFrame(frmnum);
|
} else {
|
||||||
if (mode)
|
if (mode)
|
||||||
frmnum++;
|
{
|
||||||
|
loadEEPROMFrame(frmnum);
|
||||||
|
frmnum++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
delay = delay_max;
|
||||||
}
|
}
|
||||||
|
|
||||||
// PORTD = __, 9, C, B, A,D+,D-,__
|
// PORTD = __, 9, C, B, A,D+,D-,__
|
||||||
|
@ -95,7 +99,7 @@ ISR (TIMER1_COMPA_vect)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void setFrame(uint8_t f)
|
void loadEEPROMFrame(uint8_t f)
|
||||||
{
|
{
|
||||||
frame = eeprom_read_dword( &eep_anim[f] );
|
frame = eeprom_read_dword( &eep_anim[f] );
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,7 @@ uint8_t level; // Aktive Ebene
|
||||||
uint8_t mode;
|
uint8_t mode;
|
||||||
uint8_t frmnum;
|
uint8_t frmnum;
|
||||||
uint8_t delay;
|
uint8_t delay;
|
||||||
|
uint8_t delay_max;
|
||||||
|
|
||||||
//cube_t *cube;
|
//cube_t *cube;
|
||||||
uint32_t eep_anim[32] EEMEM;
|
uint32_t eep_anim[32] EEMEM;
|
||||||
|
@ -37,7 +38,7 @@ void init(void);
|
||||||
extern void init_usb(void);
|
extern void init_usb(void);
|
||||||
extern void usbPoll(void);
|
extern void usbPoll(void);
|
||||||
|
|
||||||
void setFrame(uint8_t);
|
void loadEEPROMFrame(uint8_t);
|
||||||
|
|
||||||
#endif // __main_h__
|
#endif // __main_h__
|
||||||
|
|
||||||
|
|
|
@ -33,11 +33,9 @@ usbMsgLen_t usbFunctionSetup(uchar data[8])
|
||||||
} else if ( rq->bRequest == CUSTOM_RQ_EEPROM_STORE_FRAME )
|
} else if ( rq->bRequest == CUSTOM_RQ_EEPROM_STORE_FRAME )
|
||||||
{
|
{
|
||||||
eeprom_write_dword( &eep_anim[ rq->wIndex.bytes[0] ], frame );
|
eeprom_write_dword( &eep_anim[ rq->wIndex.bytes[0] ], frame );
|
||||||
|
} else if ( rq->bRequest == CUSTOM_RQ_SET_DELAY )
|
||||||
/*} else if ( rq->bRequest == CUSTOM_RQ_EEPROM_SET_FRAME )
|
|
||||||
{
|
{
|
||||||
//frame = eeprom_read_dword( &eep_anim[rq->wIndex.bytes[0]] );
|
delay_max = rq->wValue.bytes[0];
|
||||||
setFrame( &eep_anim[rq->wIndex.bytes[0]] );*/
|
|
||||||
} else if ( rq->bRequest == CUSTOM_RQ_SET_MODE )
|
} else if ( rq->bRequest == CUSTOM_RQ_SET_MODE )
|
||||||
{
|
{
|
||||||
mode = rq->wValue.bytes[0]; // 0 = stop; 1 = single; 2 = loop
|
mode = rq->wValue.bytes[0]; // 0 = stop; 1 = single; 2 = loop
|
||||||
|
|
|
@ -60,11 +60,12 @@ void init_usb(void);
|
||||||
extern uint32_t eep_anim[32] EEMEM;
|
extern uint32_t eep_anim[32] EEMEM;
|
||||||
|
|
||||||
// usb buffer
|
// usb buffer
|
||||||
extern uint32_t frame; // Framebuffer
|
extern uint32_t frame; // Framebuffer
|
||||||
extern uint8_t mode; // FW mode
|
extern uint8_t delay_max; // delay in ISR aufrufen
|
||||||
|
extern uint8_t mode; // FW mode
|
||||||
|
|
||||||
//extern cube_t *cube;
|
//extern cube_t *cube;
|
||||||
extern void setFrame(uint8_t f);
|
extern void loadEEPROMFrame(uint8_t f);
|
||||||
|
|
||||||
#endif // __usb_h__
|
#endif // __usb_h__
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue