### Exercício 12:

•Escrever um programa para alternar o estado dos LEDs vermelho e verde da placa MSP-EXP430G2 a cada 500.000 ciclos de *clock*.

•Utilizar o *Timer1\_A* para a temporização.

#### MSP430G2553.h:

```
#define DCO0
                      (0x20) /* DCO Select Bit 0 */
#define DCO1
                      (0x40) /* DCO Select Bit 1 */
                      (0x80) /* DCO Select Bit 2 */
#define DCO2
#define RSEL0
                      (0x01) /* Range Select Bit 0 */
                      (0x02) /* Range Select Bit 1 */
#define RSEL1
                      (0x04) /* Range Select Bit 2 */
#define RSEL2
                      (0x08) /* Range Select Bit 3 */
#define RSEL3
DCOCTL \leftarrow DCO0
BCSCTL1 \leftarrow RSEL2 + RSEL1 + RSEL0
         DCOCTL 0 0 1 0 0 0 0 0
         BCSCTL1 0 0 0 0 0 1
```

```
DCOCTL ← DCO0
BCSCTL1 ← RSEL2 + RSEL1 + RSEL0
```

## **Assembly MSP430**



DCO frequency select. These bits select which of the eight discrete DCO.



**Rits** 

**DCOx** 



| DOOR | 7-5         | frequencies within the range defined by the RSELx setting is selected.                                                                                                                                                                    |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MODx | Bits<br>4-0 | Modulator selection. These bits define how often the f <sub>DCO+1</sub> frequency is used within a period of 32 DCOCLK cycles. During the remaining clock cycles (32–MOD) the f <sub>DCO</sub> frequency is used. Not useable when DCOx-7 |
|      |             | cycles (32-MOD) the f <sub>DCO</sub> frequency is used. Not useable when DCOx=7.                                                                                                                                                          |

### **BCSCTL1, Basic Clock System Control Register 1**

| 7      | 6      | 5      | 4      | 3    | 2    | 1    | 0    |
|--------|--------|--------|--------|------|------|------|------|
| XT2OFF | хтs†   | DIVAx  |        |      | RSE  | ELx  |      |
| rw-(1) | rw-(0) | rw-(0) | rw-(0) | rw-0 | rw-1 | rw-1 | rw-1 |

<sup>†</sup> XTS = 1 is not supported in MSP430x20xx devices.

| XT2OFF | Bit 7       | <ul> <li>XT2 off. This bit turns off the XT2 oscillator</li> <li>XT2 is on</li> <li>XT2 is off if it is not used for MCLK or SMCLK.</li> </ul>             |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XTS    | Bit 6       | LFXT1 mode select.  0 Low frequency mode  1 High frequency mode                                                                                            |
| DIVAx  | Bits<br>5-4 | Divider for ACLK 00 /1 01 /2 10 /4 11 /8                                                                                                                   |
| RSELx  | Bits<br>3-0 | Range Select. Sixteen different frequency ranges are available. The lowest frequency range is selected by setting RSELx=0. RSEL3 is ignored when DCOR = 1. |

# . Typical DCOx Range and RSELx Steps





# **Assembly MSP430**



|                               | 0       | DC00    | DCO1    | DCO1 + DCO0 | DCO2    | DCO2 + DCO0 | DCO2 + DCO1 | DCO2 + DCO1 + DCO0 |
|-------------------------------|---------|---------|---------|-------------|---------|-------------|-------------|--------------------|
| 0                             | 94.9    | 101.0   | 108.1   | 116.2       | 125.6   | 136.7       | 149.9       | 166.0              |
| RSEL0                         | 118.1   | 125.8   | 134.5   | 144.6       | 156.4   | 170.1       | 186.6       | 206.5              |
| RSEL1                         | 166.6   | 177.4   | 189.7   | 203.8       | 220.2   | 239.6       | 262.7       | 290.7              |
| RSEL1 + RSEL0                 | 232.1   | 247.2   | 264.3   | 283.9       | 306.8   | 333.8       | 365.8       | 404.8              |
| RSEL2                         | 326.5   | 347.7   | 371.7   | 399.3       | 431.1   | 468.8       | 513.5       | 567.8              |
| RSEL2 + RSEL0                 | 465.0   | 497.8   | 528.8   | 567.6       | 612.8   | 665.5       | 728.9       | 805.8              |
| RSEL2 + RSEL1                 | 650.1   | 691.5   | 738.5   | 792.4       | 855.1   | 927.5       | 1015.1      | 1121.4             |
| RSEL2 + RSEL1 + RSEL0         | 921.6   | 980.2   | 1046.1  | 1121.1      | 1209.3  | 1310.3      | 1433.0      | 1581.1             |
| RSEL3                         | 1308.5  | 1390.7  | 1483.5  | 1588.5      | 1712.0  | 1852.8      | 2023.4      | 2229.9             |
| RSEL3 + RSEL0                 | 1871.1  | 1986.2  | 2116.6  | 2263.4      | 2436.6  | 2634.8      | 2874.5      | 3165.0             |
| RSEL3 + RSEL1                 | 2698.8  | 2861.8  | 3046.5  | 3252.6      | 3497.6  | 3776.8      | 4114.9      | 4529.0             |
| RSEL3 + RSEL1 + RSEL0         | 3413.7  | 3623.8  | 3862.5  | 4129.0      | 4446.5  | 4812.9      | 5255.0      | 5786.7             |
| RSEL3 + RSEL2                 | 4629.0  | 4910.4  | 5229.8  | 5579.2      | 5994.8  | 6501.5      | 7121.3      | 7796.6             |
| RSEL3 + RSEL2 + RSEL0         | 6281.3  | 6678.6  | 7118.2  | 7564.9      | 8056.5  | 8640.2      | 9469.0      | 10522.0            |
| RSEL3 + RSEL2 + RSEL1         | 8917.6  | 9499.4  | 10187.0 | 10928.9     | 11788.0 | 12680.8     | 13824.4     | 15197.5            |
| RSEL3 + RSEL2 + RSEL1 + RSEL0 | 12584.2 | 13266.5 | 14093.8 | 14939.9     | 15895.6 | 16915.7     | 18199.7     | 20405.3            |

```
#define CALDCO 16MHZ (0x10F8u) /* DCOCTL Calibration Data for 16MHz */
#define CALBC1 16MHZ
                         (0x10F9u) /* BCSCTL1 Calibration Data for 16MHz */
#define CALDCO 12MHZ
                         (0x10FAu) /* DCOCTL Calibration Data for 12MHz*/
                         (0x10FBu) /* BCSCTL1 Calibration Data for 12MHz */
#define CALBC1_12MHZ_
#define CALDCO_8MHZ_
                         (0x10FCu) /* DCOCTL Calibration Data for 8MHz */
#define CALBC1 8MHZ
                         (0x10FDu) /* BCSCTL1 Calibration Data for 8MHz */
#define CALDCO 1MHZ
                         (0x10FEu) /* DCOCTL Calibration Data for 1MHz */
#define CALBC1_1MHZ_
                          (0x10FFu) /* BCSCTL1 Calibration Data for 1MHz */
               BCSCTL1 \leftarrow CALBC1_xMHZ;
                           \leftarrow CALDCO_xMHZ;
                DCOCTL
```