====== Taimerid XMega ====== Käesolev taimerite teek katab suure osa ATXmega128A1U taimerite funktsionaalsusest. Kuna AVR taimerid on erinevate kiipide vahel päris erinevad, siis ei saa nende kasutamiseks kirjutada universaalseid funktsioone. Ka kirjeldatavad ATXmega128A1U funktsioonid on suures osas lihtsalt primitiivsed registri muutmise või lugemise funktsioonid, kuid siiski on nad loetavamad kui registrid. ===== Andmetüübid ===== * **//Timer clockSelection//** \\ Taimer 0/1 taktijaguri tegurite valiku tüüp. Väärtuste variandid ja tähendused: * //TC_CLKSEL_OFF_gc// - Jagurit ei kasutata. * //TC_CLKSEL_DIV1_gc// - Jagamistegur 1. * //TC_CLKSEL_DIV2_gc// - Jagamistegur 2. * //TC_CLKSEL_DIV4_gc// - Jagamistegur 4. * //TC_CLKSEL_DIV8_gc// - Jagamistegur 8. * //TC_CLKSEL_DIV64_gc// - Jagamistegur 64. * //TC_CLKSEL_DIV256_gc// - Jagamistegur 256. * //TC_CLKSEL_DIV1024_gc// - Jagamistegur 1024. ~~CL~~ * **//Timer wgm//** \\ Taimer 0/1 režiim. Väärtuste variandid ja tähendused: * //TC_WGMODE_NORMAL_gc// - Normaal režiim * //TC_WGMODE_FRQ_gc// - Sagedus generaator režiim * //TC_WGMODE_SINGLESLOPE_gc// - PWM režiim ainult üles loendusega * //TC_WGMODE_DSTOP_gc// - PWM režiim üles-alla loendusega, Registrite uuendus TOP väärtusel * //TC_WGMODE_DSBOTH_gc// - PWM režiim üles-alla loendusega, Registrite uuendus TOP ja BOTTOM väärtusel * //TC_WGMODE_DSBOTTOM_gc// - PWM režiim üles-alla loendusega, Registrite uuendus BOTTOM väärtusel ~~CL~~ * **//Timer katkestuste nimed ja prioriteedid.//** \\ Kõik katkestused XMega seeria mikrokontrolleritel on prioritiseeritud. * //TC_OVFINTLVL// - Ületäituvuse katkestus * //_OFF_gc// - Katkestus ei ole lubatud * //_LO_gc// - Madala prioriteediga katkestus * //_MED_gc// - Keskmise prioriteediga katkestus * //_HI_gc// - Kõrge prioriteediga katkestus * //TC_CCAINTLVL// - Võrdlusregistri katkestus * //TC_CCBINTLVL// - Võrdlusregistri katkestus * //TC_CCCINTLVL// - Võrdlusregistri katkestus * //TC_CCDINTLVL// - Võrdlusregistri katkestus * //_OFF_gc// - Katkestus ei ole lubatud * //_LO_gc// - Madala prioriteediga katkestus * //_MED_gc// - Keskmise prioriteediga katkestus * //_HI_gc// - Kõrge prioriteediga katkestus ===== Funktsioonid ===== * **//void TC0_ConfigClockSource( volatile TC0_t * tc, TC_CLKSEL_t clockSelection );//** \\ Timer0 taktigeneraatori seadistamine. * //tc// - Taimeri port * //clockSelection// - Kella seadistus * **//void TC0_ConfigWGM( volatile TC0_t * tc, TC_WGMODE_t wgm );//** \\ Timer0 režiimi seadistamine. * //tc// - Taimeri port * //wgm// - režiimi seadistus * **//void TC0_EnableCCChannels( volatile TC0_t * tc, uint8_t enableMask );//** \\ Timer0 signaaligenereerimis üksuste käivitamine * //tc// - Taimeri port * //enableMask// - Kanalid, mida käivitada (Võib loogilise OR tehtega käivitada korraga mitu) * **//void TC0_DisableCCChannels( volatile TC0_t * tc, uint8_t disableMask );//** \\ Timer0 signaaligenereerimis üksuste seiskamine * //tc// - Taimeri port * //disableMask// - Kanalid, mida seisata (Võib loogilise OR tehtega seisata korraga mitu) * **//void TC0_SetOverflowIntLevel( volatile TC0_t * tc, TC_OVFINTLVL_t intLevel );//** \\ Timer0 ületäituvuse katkestuse käivitamine * //tc// - Taimeri port * //intLevel// - ületäitumise katkestuse prioriteet * **//void TC0_SetCCAIntLevel( volatile TC0_t * tc, TC_CCAINTLVL_t intLevel );//** * **//void TC0_SetCCBIntLevel( volatile TC0_t * tc, TC_CCBINTLVL_t intLevel );//** * **//void TC0_SetCCCIntLevel( volatile TC0_t * tc, TC_CCCINTLVL_t intLevel );//** * **//void TC0_SetCCDIntLevel( volatile TC0_t * tc, TC_CCDINTLVL_t intLevel );//** \\ Timer0 signaaligenereerimis viigu A/B/C/D katkestuse seadistamine * //tc// - Taimeri port * //intLevel// - Võrdlusregistri katkestuse prioriteet * **//void TC0_Reset( volatile TC0_t * tc );//** Timer0 taaskäivitus * //tc// - Taimeri port Kõik funktsioonid kehtivad sarnaselt ka Taimer1 kohta. ===== Makrod ===== * **//TC_SetCount( _tc, _count )//** Võimaldab taimeri väärtust käsitsi muuta * //_tc// - Taimeri moodul * //_count// - seadesuurus * **//TC_SetPeriod( _tc, _period )//** Seadistab taimeri perioodi * //_tc// - Taimeri moodul * //_period// - perioodi seadesuurus * **//TC_SetCompareA( _tc, _compareValue )//** * **//TC_SetCompareB( _tc, _compareValue )//** * **//TC_SetCompareC( _tc, _compareValue )//** * **//TC_SetCompareD( _tc, _compareValue )//** Sea väärtus, millega toimub kanali võrdlus * //_tc// - Taimeri moodul * //_compareValue// - seadesuurus * **//TC_GetOverflowFlag( _tc )//** Kontrolli ületäituvuse lippu * //_tc// - Taimeri moodul * **//TC_ClearOverflowFlag( _tc )//** Puhasta ületäituvuse lipp * //_tc// - Taimeri moodul * **//TC_GetCCAFlag( _tc )//** * **//TC_GetCCBFlag( _tc )//** * **//TC_GetCCCFlag( _tc )//** * **//TC_GetCCDFlag( _tc )//** Kontrolli signaaligeneraatori lippu * //_tc// - Taimeri moodul * **//TC_ClearCCAFlag( _tc )//** * **//TC_ClearCCBFlag( _tc )//** * **//TC_ClearCCCFlag( _tc )//** * **//TC_ClearCCDFlag( _tc )//** Puhasta signaaligeneraatori lipp * //_tc// - Taimeri moodul * **//TC_GetCaptureA( _tc )//** * **//TC_GetCaptureB( _tc )//** * **//TC_GetCaptureC( _tc )//** * **//TC_GetCaptureD( _tc )//** Kontrolli sündmuste loendurit * //_tc// - Taimeri moodul ===== Näide ===== Näites seadistatakse Pordi E Timer0 tavalisse loendamise režiimi ja lubatakse ületäitumise ning võrdluskanali A katkestus. #include #include #include #include // Ületäituvuse katkestus ISR(TCE0_OVF_vect) { led_on(led_green); } // Võrdluskanali A katkestus ISR(TCE0_CCA_vect) { led_off(led_green); } int main(void) { // Seadista roheline LED väljundiks pin_setup_output(led_green); led_off(led_green); // Seame taimer E0i perioodi // Seame taimer E0i töötsükli pikkuse TC_SetPeriod(&TCE0, 20000); TC_SetCompareA(&TCE0, 15000); // Seame taimer E0i taktsageduse (F_CPU/1024) TC0_ConfigClockSource(&TCE0, TC_CLKSEL_DIV1024_gc); // Seame taimer E0i töötama normaalrežiimis TC0_ConfigWGM(&TCE0, TC_WGMODE_NORMAL_gc); // Lubame ületäituvuse katkestuse kõrge prioriteediga // Lubame värdluskanali A katkestuse keskmise prioriteediga TC0_SetOverflowIntLevel(&TCE0,TC_OVFINTLVL_HI_gc); TC0_SetCCAIntLevel(&TCE0, TC_CCAINTLVL_MED_gc); // Lubame keskmised ja kõrge prioriteedika katkestused // Lubame globaalselt katkestused PMIC.CTRL |= PMIC_MEDLVLEN_bm|PMIC_HILVLEN_bm; sei(); //Tühi tsükkel, programm jookseb katkestuste peal while(1); }