60 likes | 218 Views
msp430x20x3_1.c -Software Toggle P1.0. #include <msp430x20x3.h> void main(void) { WDTCTL = WDTPW + WDTHOLD; P1DIR |= 0x01; for (;;) { volatile unsigned int i; P1OUT ^= 0x01; i = 50000;
E N D
msp430x20x3_1.c -Software Toggle P1.0 #include <msp430x20x3.h> void main(void) { WDTCTL = WDTPW + WDTHOLD; P1DIR |= 0x01; for (;;) { volatile unsigned int i; P1OUT ^= 0x01; i = 50000; do (i--); while (i != 0); } } Άσκηση. Μεταγλωττίστε και τρέξτε τον κώδικα. Συμπληρώστε τα σχόλια που να εξηγούν τί κάνει ο κώδικας. Ποιο υποσύστημα ρολογιού χρησιμοποιεί;
msp430x20x3_1_vlo.c -Software Toggle P1.0, MCLK = VLO/8 #include <msp430x20x3.h> void main(void) { volatile unsigned inti; // ___________________________________ WDTCTL = WDTPW + WDTHOLD; // ___________________________________ BCSCTL3 |= LFXT1S_2; // ___________________________________ IFG1 &= ~OFIFG; // ___________________________________ __bis_SR_register(SCG1 + SCG0); // ___________________________________ BCSCTL2 |= SELM_3 + DIVM_3; // ___________________________________ P1DIR = 0xFF; // ___________________________________ P1OUT = 0; // ___________________________________ P2DIR = 0xFF; // ___________________________________ P2OUT = 0; // ___________________________________ for (;;) { P1OUT |= 0x01; // ___________________________________ for (i = 10; i > 0; i--); // ___________________________________ P1OUT &= ~0x01; // ___________________________________ for (i = 1000; i > 0; i--); // ___________________________________ } } Άσκηση. Μεταγλωττίστε και τρέξτε τον κώδικα. Συμπληρώστε τα σχόλια που να εξηγούν τί κάνει ο κώδικας. Με ποια συχνότητα τροφοδοτείται μέσω λογισμικού και ποιός ακροδέκτης; Σε τί διαμόρφωση βρίσκεται το ACLK, το MCLK και το SMCLK;
msp430x20x3_clks.c-Basic Clock, Output Buffered SMCLK, ACLK and MCLK/10 #include <msp430x20x3.h> void main(void) { WDTCTL = WDTPW +WDTHOLD; // ___________________________________ P1DIR |= 0x13; // ___________________________________ P1SEL |= 0x11; // ___________________________________ while(1) { P1OUT |= 0x02; // ___________________________________ P1OUT &= ~0x02; // ___________________________________ } } Άσκηση. Μεταγλωττίστε και τρέξτε τον κώδικα. Συμπληρώστε τα σχόλια που να εξηγούν τί κάνει ο κώδικας. Πώς έχουν οι συνδέσεις των ACLK, MCLK, SMCLK;
msp430x20xx_dco_flashcal.c-DCO Calibration Constants Programmer #include <msp430x20x2.h> void main(void) { WDTCTL = WDTPW +WDTHOLD; // ___________________________________ if (CALBC1_1MHZ ==0xFF || CALDCO_1MHZ == 0xFF) { while(1); // ___________________________________ // ___________________________________ } //1Mhz BCSCTL1 = CALBC1_1MHZ; // ___________________________________ DCOCTL = CALDCO_1MHZ; // ___________________________________ /* //8Mhz BCSCTL1 = CALBC1_8MHZ; // ___________________________________ DCOCTL = CALDCO_8MHZ; // ___________________________________ /* //12Mhz BCSCTL1 = CALBC1_12MHZ; // ___________________________________ DCOCTL = CALDCO_12MHZ; // ___________________________________ /* //16Mhz BCSCTL1 = CALBC1_16MHZ; // ___________________________________ DCOCTL = CALDCO_16MHZ; // ___________________________________ P1DIR |= 0x13; // ___________________________________ P1SEL |= 0x11; // ___________________________________ while(1) { P1OUT |= 0x02; // ___________________________________ P1OUT &= ~0x02; // ___________________________________ } } Άσκηση. Μεταγλωττίστε και τρέξτε τον κώδικα. Συμπληρώστε τα σχόλια που να εξηγούν τί κάνει ο κώδικας. Πως έχουν οι συνδέσεις των ACLK, MCLK, SMCLK.
msp430x20x3_flashwrite_01.c- Flash In-System Programming, Copy SegC to SegD void write_SegC (char value) { char *Flash_ptr; // ___________________________________ unsigned inti; Flash_ptr = (char *) 0x1040; // ___________________________________ FCTL1 = FWKEY + ERASE; // ___________________________________ FCTL3 = FWKEY; // ___________________________________ *Flash_ptr = 0; // ___________________________________ FCTL1 = FWKEY + WRT; // ___________________________________ for (i=0; i<64; i++) { *Flash_ptr++ = value; // ___________________________________ } FCTL1 = FWKEY; // ___________________________________ FCTL3 = FWKEY + LOCK; // ___________________________________ } void copy_C2D (void) { char *Flash_ptrC; // ___________________________________ char *Flash_ptrD; // ___________________________________ unsigned inti; Flash_ptrC = (char *) 0x1040; // ___________________________________ Flash_ptrD = (char *) 0x1000; // ___________________________________ FCTL1 = FWKEY + ERASE; // ___________________________________ FCTL3 = FWKEY; // ___________________________________ *Flash_ptrD = 0; // ___________________________________ FCTL1 = FWKEY + WRT; // ___________________________________ for (i=0; i<64; i++) { *Flash_ptrD++ = *Flash_ptrC++; // ___________________________________ } FCTL1 = FWKEY; // ___________________________________ FCTL3 = FWKEY + LOCK; // ___________________________________ } #include <msp430x20x3.h> char value; // ___________________________________ // Function prototypes void write_SegC (char value); void copy_C2D (void); void main(void) { WDTCTL = WDTPW + WDTHOLD; // ___________________________________ if (CALBC1_1MHZ ==0xFF || CALDCO_1MHZ == 0xFF) { while(1); // ___________________________________ // ___________________________________ } BCSCTL1 = CALBC1_1MHZ; // ___________________________________ DCOCTL = CALDCO_1MHZ; FCTL2 = FWKEY + FSSEL0 + FN1; // ___________________________________ value = 0; // ___________________________________ while(1) // ___________________________________ { write_SegC(value++); // ___________________________________ copy_C2D(); // ___________________________________ _NOP(); // ___________________________________ } } Άσκηση. Μεταγλωττίστε και τρέξτε τον κώδικα. Συμπληρώστε τα σχόλια που να εξηγούν τί κάνει ο κώδικας. Ποια είναι η συχνότητα του MCLK; Ποιος ο ρόλος του _NOP();
msp430x20x3_LFxtal_nmi.c-LFXT1 Oscillator Fault Detection #include <msp430x20x3.h> volatile unsigned inti; void main(void) { WDTCTL = WDT_ADLY_1000; // ___________________________________ IE1 |= WDTIE; // ___________________________________ P1DIR = 0xFF; // ___________________________________ P1OUT = 0; // ___________________________________ P2DIR = 0xFF; // ___________________________________ P2OUT = 0; // ___________________________________ IE1 |= OFIE; // ___________________________________ while(1) { P1OUT ^= 0x01; // ___________________________________ _BIS_SR(LPM3_bits + GIE); // ___________________________________ } } #pragma vector=WDT_VECTOR __interrupt void watchdog_timer (void) { _BIC_SR_IRQ(LPM3_bits); // ___________________________________ } #pragma vector=NMI_VECTOR __interrupt void nmi_ (void) { do { IFG1 &= ~OFIFG; // ___________________________________ for (i = 0xFFF; i > 0; i--); // ___________________________________ P1OUT ^= 0x01; // ___________________________________ } while (IFG1 & OFIFG); // ___________________________________ IE1 |= OFIE; / // ___________________________________ } Άσκηση. Μεταγλωττίστε και τρέξτε τον κώδικα. Συμπληρώστε τα σχόλια που να εξηγούν τί κάνει ο κώδικας. Σε ποιον τρόπο λειτουργίας εκτελείται το πρόγραμμας Πώς έχουν οι συνδέσεις και οι συχνότητες των ACLK, MCLK, SMCLK;