

## DAC Kullanımı

25 Aralık 2021 Cumartesi 00:57

## DAC Kullanımı

➤ HAL

## Konfigürasyon Kısmı



| Pin N... | Signal on... | GPIO out... | GPIO mo... | GPIO Pul...  | Maximu... | User Label | Modified                 |
|----------|--------------|-------------|------------|--------------|-----------|------------|--------------------------|
| PA4      | DAC_O...     | n/a         | Analog ... | No pull-u... | n/a       |            | <input type="checkbox"/> |

- DAC kısmından OUT1 seçiyoruz.

OUT1 Configuration

OUT2 Configuration

External Trigger

  - Output Buffer, gürültü engelleme; Trigger tetiklemedir.  
Biz bunları aynı şekilde bırakıyoruz.

DAC Out1 Settings

Output Buffer Enable  
Trigger None

Mugge

- DAC için toplam iki kanal var.

```
[..]
*** DAC Channels ***
=====
[..]
STM32F4 devices integrate two 12-bit Digital Analog Converter
The 2 converters (i.e. channel1 & channel2)
can be used independently or simultaneously (dual mode):
 (#) DAC channel1 with DAC_OUT1 (PA4) as output
 (#) DAC channel2 with DAC_OUT2 (PA5) as output
```
  - DAC kullanmak için iki modumuz var. Biri Polling diğeri DMA'dır.

```

110     *** Polling mode IO operation ***
111     =====
112     [...]
113         (+) Start the DAC peripheral using HAL_DAC_Start()
114         (+) To read the DAC last data output value, use the HAL_DAC_GetValue() function.
115         (+) Stop the DAC peripheral using HAL_DAC_Stop()

435 HAL_StatusTypeDef HAL_DAC_Start(DAC_HandleTypeDef *hdac, uint32_t Channel)
• DAC için değer verme yapacağımızdan GetValue değil SetValue kullanacağız. Çıkışın voltaj değeri ile oynamış oluyoruz.

759 /**
760  * @brief Set the specified data holding register value for DAC channel.
761  * @param hdac pointer to a DAC_HandleTypeDef structure that contains
762  *             the configuration information for the specified DAC.
763  * @param Channel The selected DAC channel.
764  *             This parameter can be one of the following values:
765  *             @arg DAC_CHANNEL_1: DAC Channel1 selected
766  *             @arg DAC_CHANNEL_2: DAC Channel2 selected
767  * @param Alignment Specifies the data alignment.
768  *             This parameter can be one of the following values:
769  *             @arg DAC_ALIGN_8B_R: 8bit right data alignment selected
770  *             @arg DAC_ALIGN_12B_L: 12bit left data alignment selected
771  *             @arg DAC_ALIGN_12B_R: 12bit right data alignment selected
772  * @param Data Data to be loaded in the selected data holding register.
773  * @retval HAL status
774 */
775 HAL_StatusTypeDef HAL_DAC_SetValue(DAC_HandleTypeDef *hdac, uint32_t Channel, uint32_t Alignment, uint32_t Data)
• Data kısmına 12 bit çalıştığımızdan 0-4095 arasında değer yazabiliyoruz.

23 /* Private includes -----
24 /* USER CODE BEGIN Includes */
25 int i=0;
26 /* USER CODE END Includes */

91 /* USER CODE BEGIN 2 */
92 HAL_DAC_Start(&hdac, DAC_CHANNEL_1);
/* USER CODE END 2 */

95 /* Infinite loop */
96 /* USER CODE BEGIN WHILE */
97 while (1)
{
    /* USER CODE END WHILE */
100
101 /* USER CODE BEGIN 3 */
102 do
{
    HAL_DAC_SetValue(&hdac, DAC_CHANNEL_1, DAC_ALIGN_12B_R, i);
    HAL_Delay(1);
    i++;
}
108 while(i<4096);
i=0;
110 }
/* USER CODE END 3 */

```

## ➤ REGISTER

### Konfigürasyon Kısımları

- RCC için 5.satırda 0x00030000 yerine 0x00010000 yazdık.  
HSERDY kısmı sadece okunabilir olduğundan o biti 1 yapmıyoruz.

```

3 @void RCC_Config(void)
4 {
5     RCC->CR |= 0x00010000;           //HSEON
6     while(!(RCC->CR & 0x00020000)); //HSERDY
7     RCC->CR |= 0x00080000;           //CSSON
8     RCC->CFGR = 0x00000000;
9     RCC->PLLCFGR |= 0x00400000;      //PLLSRC
10    RCC->PLLCFGR |= 0x00000004;       //PLLM 4
11    RCC->PLLCFGR |= 0x00002A00;       //PLLN 168
12    RCC->PLLCFGR |= 0x00000000;       //PLLP 2
13    RCC->CR |= 0x01000000;           //PLLON
14    while(!(RCC->CR & 0x02000000)); //PLLRDY
15    RCC->CFGR |= 0x00000001;          //SW
16    while(!(RCC->CR & 0x00000001)); //SWS
17 }

```

- ADC'nin clock hattı APB1'e gitiyor.



### 7.3.13 RCC APB1 peripheral clock enable register (RCC\_APB1ENR)

Address offset: 0x40

Reset value: 0x0000 0000

Access: no wait state, word, half-word and byte access.

| 31       | 30      | 29       | 28            | 27       | 26       | 25            | 24       | 23      | 22      | 21       | 20       | 19         | 18         | 17            | 16 |
|----------|---------|----------|---------------|----------|----------|---------------|----------|---------|---------|----------|----------|------------|------------|---------------|----|
| Reserved | DAC EN  | PWR EN   | Reser-<br>ved | CAN2 EN  | CAN1 EN  | Reser-<br>ved | I2C3 EN  | I2C2 EN | I2C1 EN | UART5 EN | UART4 EN | USART 3 EN | USART 2 EN | Reser-<br>ved |    |
|          | RW      | RW       |               | RW       | RW       |               | RW       | RW      | RW      | RW       | RW       | RW         | RW         | RW            |    |
| 15       | 14      | 13       | 12            | 11       | 10       | 9             | 8        | 7       | 6       | 5        | 4        | 3          | 2          | 1             | 0  |
| SPI3 EN  | SPI2 EN | Reserved | WWDG EN       | Reserved | TIM14 EN | TIM13 EN      | TIM12 EN | TIM7 EN | TIM6 EN | TIM5 EN  | TIM4 EN  | TIM3 EN    | TIM2 EN    |               |    |
| RW       | RW      |          | RW            |          | RW       | RW            | RW       | RW      | RW      | RW       | RW       | RW         | RW         | RW            |    |

- 29.pini 1 yapıyoruz.

Bit 29 **DACEN**: DAC interface clock enable

Set and cleared by software.

0: DAC interface clock disabled

1: DAC interface clock enable

RCC->**APB1ENR** |= 0x20000000; //DACEN

## DAC control register (DAC\_CR)

Address offset: 0x00

Reset value: 0x0000 0000

- DAC işlemi için channel1 kullanacağımızdan 0.biti aktif etmemiz gerekiyor.

Bit 0 EN1: DAC channel1 enable

This bit is set and cleared by software to enable/disable DAC channel1.

0: DAC channel1 disabled

1: DAC channel1 enabled

```
DAC->CR |= 0x00000001;
```

- Yazılımsal tetikleme kullanmadığımızdan 0. biti 0 yapıyoruz.

## DAC software trigger register (DAC\_SWTRIGR)

Address offset: 0x04

Reset value: 0x0000 0000

Bit 0 **SWTRIG1**: DAC channel1 software trigger

This bit is set and cleared by software to enable/disable the software trigger.

0: Software trigger disabled

### 1: Software trigger enabled

**Note:** This bit is cleared by hardware (one APB1 clock cycle later) once the DAC\_DHR1 register value has been loaded into the DAC\_DOR1 register.

DAC ->SWTRIGR |= 0x00000000;

- Channel1 için 12 bit sağa ya da sola veya 8 bit sağa kaydedebiliriz.

## DAC channel1 12-bit right-aligned data holding register (DAC\_DHR12R1)

Address offset: 0x08

Reset value: 0x0000 0000

## DAC channel1 12-bit left aligned data holding register (DAC\_DHR12L1)

Address offset: 0x0C

Reset value: 0x0000 0000

|                |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|
| 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17       | 16 |
| Reserved       |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
| 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1        | 0  |
| DACC1DHR[11:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
| RW             | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | Reserved |    |

## DAC channel1 8-bit right aligned data holding register (DAC\_DHR8R1)

Address offset: 0x10

Reset value: 0x0000 0000

|          |    |    |    |    |    |    |    |               |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|----|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |    |    |    |    |    |    |    |               |    |    |    |    |    |    |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Reserved |    |    |    |    |    |    |    | DACC1DHR[7:0] |    |    |    |    |    |    |    |
|          |    |    |    |    |    |    |    | rw            | rw | rw | rw | rw | rw | rw | rw |

- 12 bit sağa kaydedecekiz.

Bits 11:0 DACC1DHR[11:0]: DAC channel1 12-bit right-aligned data

These bits are written by software which specifies 12-bit data for DAC channel1.

## RCC AHB1 peripheral clock enable register (RCC\_AHB1ENR)

Address offset: 0x30

Reset value: 0x0010 0000

Access: no wait state, word, half-word and byte access.

|               |                         |             |                     |                    |                    |              |             |             |             |            |                  |             |               |             |    |  |
|---------------|-------------------------|-------------|---------------------|--------------------|--------------------|--------------|-------------|-------------|-------------|------------|------------------|-------------|---------------|-------------|----|--|
| 31            | 30                      | 29          | 28                  | 27                 | 26                 | 25           | 24          | 23          | 22          | 21         | 20               | 19          | 18            | 17          | 16 |  |
| Reser-<br>ved | OTGH<br>S<br>ULPIE<br>N | OTGH<br>SEN | ETHM<br>ACPTP<br>EN | ETHM<br>ACRXE<br>N | ETHM<br>ACTXE<br>N | ETHMA<br>CEN | Reserved    |             | DMA2E<br>N  | DMA1E<br>N | CCMDAT<br>ARAMEN | Res.        | BKPSR<br>AMEN | Reserved    |    |  |
|               | rw                      | rw          | rw                  | rw                 | rw                 | rw           |             |             | rw          | rw         |                  |             | rw            |             |    |  |
| 15            | 14                      | 13          | 12                  | 11                 | 10                 | 9            | 8           | 7           | 6           | 5          | 4                | 3           | 2             | 1           | 0  |  |
| Reserved      |                         | CRCE<br>N   | Reserved            |                    |                    | GPIOE<br>N   | GPIOH<br>EN | GPIOG<br>EN | GPIOF<br>EN | GPIOEEN    | GPIOD<br>EN      | GPIOC<br>EN | GPIO<br>BEN   | GPIO<br>AEN |    |  |
|               |                         | rw          |                     |                    |                    | rw           | rw          | rw          | rw          | rw         | rw               | rw          | rw            | rw          |    |  |

- DAC1 A4 pini olduğundan portunu sadece A portunu aktif ediyoruz.

RCC->AHB1ENR |= 0x00000001;

- RCC ve DAC1 için yazdığımız fonksiyonlar aşağıdaki gibidir.

```

10 void RCC_Config(void)
11 {
12     RCC->CR |= 0x00010000; //HSEON
13     while(!(RCC->CR & 0x00020000)); //HSERDY
14     RCC->CR |= 0x00080000; //CSSON
15     RCC->CFGR = 0x00000000;
16     RCC->PLLCFGR |= 0x00400000; //PLLSRC
17     RCC->PLLCFGR |= 0x00000004; //PLLM 4
18     RCC->PLLCFGR |= 0x00002A00; //PLLN 168
19     RCC->PLLCFGR |= 0x00000000; //PLLP 2
20     RCC->CR |= 0x01000000; //PLLON
21     while(!(RCC->CR & 0x02000000)); //PLLRDY
22     RCC->CFGR |= 0x00000001; //SW
23     while(!(RCC->CR & 0x00000001)); //SWS
24 }

26 void DAC1_Config(void)
27 {
28     RCC->APB1ENR |= 0x20000000; //DACEN
29     RCC->AHB1ENR |= 0x00000001; //A clock enable
30
31     DAC->CR |= 0x00000001; //DAC channel1 enabled
32     DAC->SWTRIGR |= 0x00000000; //Software trigger disabled
33     DAC->DHR12R1 |= 0x00000000; //DAC channel1 12-bit right-aligned data
34 }

```

Kod Kısımlı

```
3 int i=0;
4
5 void delay(uint32_t time)
6 {
7     while(time--);
8 }
36 int main(void)
37 {
38     RCC_Config();
39     SystemCoreClockUpdate();
40     DAC1_Config();
41
42     while (1)
43     {
44         for(;i<4096; i++)
45         {
46             DAC->DHR12R1 |= i;
47             delay(16800);
48         }
49         i=0;
50     }
51 }
```

- Her i değeri arttığında i değeri kadar kaydetmiş oluyor.
- A4 pinine led bağladığımızda i değeri arttıkça voltaj değeri artacağından parlaklık artar.
- 4095 olduğunda yani 0x0000FFF olduğunda tam parlaklıktır yanar.