



**Universidade Federal de Santa Catarina**

**Centro Tecnológico**

Departamento de Informática e Estatística  
Ciências da Computação & Engenharia Eletrônica



# Sistemas Digitais

**INE 5406**

## Aula 2-T

- 1. Componentes do Nível RT: Temporização e Análise de Timing.  
Atraso de componentes, diagramas de tempos, período mínimo  
do relógio, atraso crítico, tempo de estabilização dos sinais,  
caminho crítico.**

**Profs. José Luís Güntzel e Cristina Meinhardt**  
[{j.guntzel, cristina.meinhardt}@ufsc.br](mailto:{j.guntzel, cristina.meinhardt}@ufsc.br)

# Temporização e Análise de Timing

## Atraso (de propagação) de uma porta lógica

É o tempo que transcorre entre uma transição de entrada e a consequente transição na saída da porta.

**Exemplo 1:** sinais com formas de onda “minimamente realistas”



$tp_{HL} = td_{HL}$  = atraso de descida  
 $tp_{LH} = td_{LH}$  = atraso de subida



A menos que se diga o  
contrário assumiremos que  
 $tp_{HL} = tp_{LH}$  (= tp ou td)

# Temporização e Análise de Timing

## Atraso (de propagação) de uma porta lógica

É o tempo que transcorre entre uma transição de entrada e a consequente transição na saída da porta.

**Exemplo 1:** sinais com formas de onda “digitalizadas” (abstração da realidade)



$tp_{HL} = td_{HL}$  = atraso de descida  
 $tp_{LH} = td_{LH}$  = atraso de subida



A menos que se diga o  
contrário assumiremos que  
 $tp_{HL} = tp_{LH}$  (= tp ou td)

# Temporização e Análise de Timing

## Atraso (de propagação) de uma porta lógica

É o tempo que transcorre entre uma transição de entrada e a consequente transição na saída da porta.

### Exemplo 2



A menos que se diga o  
contrário, assumiremos  
que  $tp_{HL}(A) = tp_{LH}(A) =$   
 $tp_{HL}(B) = tp_{LH}(B) =$   
 $tp$  (ou  $td$ )

# Temporização e Análise de Timing

---

## Cadenciamento de Sistemas Digitais

- A maior parte dos sistemas digitais são sincronizados por um sinal monótono denominado relógio (ou *clock*, em inglês).
- Sistemas digitais cadenciados por sinal de relógio são denominados síncronos.
- No projeto de sistemas digitais síncronos, registradores são utilizados.

# Temporização e Análise de Timing

## Estimativa do Período do Relógio

Uma execução por ciclo de relógio...



Para que C1 tenha tempo suficiente para realizar sua operação, é necessário que:

$$T \geq D$$

Onde D = atraso crítico entre R1 e R2, calculado por :

$$D = t_{coR1} + t_{dC1} + t_{suR2}$$



# Temporização e Análise de Timing

## Sinal de Relógio (ou *Clock*)



### Nomenclatura

borda ascendente =  
borda de subida =  
borda positiva =  
flanco de subida etc

borda descendente =  
borda de descida =  
borda negativa =  
flanco de descida etc

### Características:

- Período ( $T$ ): tempo entre duas bordas consecutivas de mesmo tipo.  
Medido em submúltiplos do segundo (ms,  $\mu$ s, ns)
- Frequência:  $f = 1/T$ , medida em múltiplos do hertz (kHz, MHz, GHz)
- *Duty cycle*:  $T_1/T \times 100\%$ , onde  $T_1$  é o tempo entre uma borda ascendente e a borda descendente que a segue.

# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

No diagrama abaixo, considerar que cada divisão vale 1,0 ns



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |



# Temporização e Análise de Timing

## Diagramas de Tempo

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

(Também conhecido como *Arrival Time*)

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar (geralmente, a partir de uma dada borda de relógio)

Exemplo 1:



$$TE(S) = \max \{TE(A), TE(B)\} + td(g)$$

Suponha que  $TE(A) = 10 \text{ ps}$ ,  $TE(B) = 12 \text{ ps}$ ,  $td(g) = 2 \text{ ps}$ .

Calcular  $TE(S)$ .

$$TE(S) = \max \{10 \text{ ps}, 12 \text{ ps}\} + 2 \text{ ps} = 14 \text{ ps}$$

Obs: ao longo desta disciplina, consideraremos que os fios tem atraso desprezível, o que não corresponde à realidade, mas serve como abordagem inicial.

# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Analisaremos um somador paralelo de 4 bits construído com n somadores completos (*full adders*).



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Considerando TE = 0 para as entradas do circuito e os atrasos de propagação mostrados na tabela ao lado, determine os TEs de todas as saídas

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Considerando TE = 0 para as entradas do circuito e os atrasos de propagação mostrados na tabela ao lado, determine os TEs de todas as saídas

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Considerando TE = 0 para as entradas do circuito e os atrasos de propagação mostrados na tabela ao lado, determine os TEs de todas as saídas

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Considerando TE = 0 para as entradas do circuito e os atrasos de propagação mostrados na tabela ao lado, determine os TEs de todas as saídas

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Considerando TE = 0 para as entradas do circuito e os atrasos de propagação mostrados na tabela ao lado, determine os TEs de todas as saídas

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Considerando TE = 0 para as entradas do circuito e os atrasos de propagação mostrados na tabela ao lado, determine os TEs de todas as saídas

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Considerando TE = 0 para as entradas do circuito e os atrasos de propagação mostrados na tabela ao lado, determine os TEs de todas as saídas

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Considerando TE = 0 para as entradas do circuito e os atrasos de propagação mostrados na tabela ao lado, determine os TEs de todas as saídas

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Considerando TE = 0 para as entradas do circuito e os atrasos de propagação mostrados na tabela ao lado, determine os TEs de todas as saídas

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Tempo de Estabilização (TE) de um Sinal

Definição: TE de um sinal é o máximo tempo que o sinal demora para estabilizar

**Exemplo 2:** Considerando TE = 0 para as entradas do circuito e os atrasos de propagação mostrados na tabela ao lado, determine os TEs de todas as saídas

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Caminho Crítico

É o caminho (i.e., a sucessão de componentes) atravessado pela sequência de transições mais lentas.

No exemplo, há **dois** caminhos críticos com atraso 19 ps:

$$\begin{aligned} A_0 &\rightarrow x_1 \rightarrow n_2 \rightarrow n_3 \rightarrow n_5 \rightarrow n_6 \rightarrow n_8 \rightarrow n_9 \rightarrow n_{11} \rightarrow n_{12} \rightarrow C_{\text{out}} \\ B_0 &\rightarrow x_1 \rightarrow n_2 \rightarrow n_3 \rightarrow n_5 \rightarrow n_6 \rightarrow n_8 \rightarrow n_9 \rightarrow n_{11} \rightarrow n_{12} \rightarrow C_{\text{out}} \end{aligned}$$

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Atraso Crítico

É o atraso do caminho crítico.

No exemplo, atraso do caminho caminho crítico = 19 ps

**No pior caso**, este é o tempo que este circuito precisa para completar uma adição entre dois números de 4 bits.

| porta | td   |
|-------|------|
| inv   | 1 ps |
| nand2 | 2ps  |
| xor   | 3ps  |



# Temporização e Análise de Timing

## Atraso Crítico para um Somador de $n$ Bits



Por uma questão de simplificação do cálculo, iremos aproximar o atraso de um somador de  $n$  bits por  $n \times$  atraso entre *carry in* e *carry out* de um meio somador (neste caso, seria 4 ps)

# Temporização e Análise de Timing

Atraso Crítico no Nível Lógico → Atraso de Componente do Nível RT

Nível Lógico



Nível RT



Por uma questão de simplificação, no nível RT considera-se que qualquer saída do componente (combinacional) possui atraso = td, no caso deste exemplo:

$$td(\text{somador\_4bits}) = 4 \times 4\text{ps} = 16\text{ ps}$$

# Temporização e Análise de Timing

## Tempo de Estabilização (TE) no Nível RT

Para Elementos Combinacionais (exceto muxes)



$$\begin{aligned} \text{TE}(S) &= \max \{ \text{TE}(A), \text{TE}(B) \} + \text{td}(\text{somador}) \\ \text{TE}(C_{\text{out}}) &= \max \{ \text{TE}(A), \text{TE}(B) \} + \text{td}(\text{somador}) \end{aligned}$$



$$\begin{aligned} \text{TE(res)} &= \max\{\text{TE}(A), \text{T}(B), \text{T(controle)}\} + \text{td(ULA)} \\ \text{TE(zero)} &= \max\{\text{TE}(A), \text{T}(B), \text{T(controle)}\} + \text{td(ULA)} \end{aligned}$$

# Temporização e Análise de Timing

## Tempo de Estabilização (TE) no Nível RT

Para muxes



$$TE(Y) = \max\{TE_S, TE(\text{sel})\} + td(\text{mux})$$

Onde:  
 $TE_S = TE(A)$  se  $\text{sel} = 0$   
e  
 $TE_S = TE(B)$  se  $\text{sel} = 1$

# Temporização e Análise de Timing

## Tempo de Estabilização (TE) no Nível RT

Para Registradores



\* Toma-se a borda de relógio  $t_0$  como referência de tempo; logo, TE = tco após  $t_0$ .

# Temporização e Análise de Timing

## Tempos de Estabilização

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

A análise inicia assumindo-se uma primeira borda de relógio ( $t_0$ ) aplicada a R1 e R2



# Temporização e Análise de Timing

## Tempos de Estabilização

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |



# Temporização e Análise de Timing

## Tempos de Estabilização

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |



# Temporização e Análise de Timing

## Tempos de Estabilização

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |



# Temporização e Análise de Timing

## Caminhos Críticos e Atraso Crítico

Supondo as seguintes características temporais dos componentes

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |



# Temporização e Análise de Timing

## Estimativa do Período (Mínimo) e da Frequência Máxima do Relógio



Período mínimo do relógio = D = 4ns

$$\begin{aligned}\text{Frequência máxima} &= 1 / \text{período mínimo} = 1 / 4 \text{ ns} = 1 / 4 \times 10^{-9} \text{ s} = \\ &= 0,25 \times 10^{9} \text{ Hz} = 250 \times 10^6 \text{ Hz} = 250 \text{ MHz}\end{aligned}$$

# Temporização e Análise de Timing

## Estimativa do Período (Mínimo) do Relógio (2)

Pode-se pular a etapa de determinação dos TEs, calculando o atraso crítico diretamente a partir do(s) caminho(s) crítico(s). Exemplo:

$$\begin{aligned} D &= \max\{ tco_{R1}, tco_{R2} \} + 8.tds + tsu_{R3} = \\ &= 1 \text{ ns} + 8 \cdot 0,25 \text{ ns} + 1 \text{ ns} = 4 \text{ ns} \end{aligned}$$



# Temporização e Análise de Timing

---

Suponha que necessita-se de um hardware dedicado para realizar o seguinte cálculo:

$$S \leftarrow A + B + C + D$$

Assumir que as variáveis A, B, C e D sejam números inteiros sem sinal, representados em binário com 8 bits, **estando disponíveis ao mesmo tempo**.

- Como as variáveis de entrada estão disponíveis ao mesmo tempo, pode ser vantajoso executar este cálculo em um ciclo de relógio.
- Para reduzir o período do relógio, é importante explorar o paralelismo que o cálculo pode proporcionar.

# Temporização e Análise de Timing

## Solução 1:

ULA dedicada que realiza o cálculo de maneira paralela



Neste esquemático:

- O comprimento (i.e., o nº de bits) do registrador “S”  
restringe o uso desta ULA para operações nas quais o resultado  
não ultrapasse 255. Portanto,  
pode ocorrer *overflow*!

# Temporização e Análise de Timing

## Solução 1.1:

ULA dedicada que realiza o cálculo de maneira paralela que evita ocorrência de overflow



Ponto Positivo:

- Jamais ocorre overflow.

Ponto Negativo:

- Este desenho **não** deixa claro como é gerado o bit mais significativo da saída dos somadores!

# Temporização e Análise de Timing

**Solução 1.2** (segundo as convenções do nível RT):  
ULA dedicada que realiza o cálculo de maneira paralela e  
evita ocorrência de overflow



Pontos Positivos:

- Jamais ocorre *overflow*.
- Este esquemático deixa claro como é gerado o bit mais significativo da saída dos somadores.

Ponto Negativo:

- 2 somadores p/ números com 9 bits e 1 somador para números de 10 bits. Logo, o custo não é mínimo (porque usa mais recursos do que o necessário). Além disso, o atraso crítico tampouco é mínimo.

# Temporização e Análise de Timing

**Solução 1.3** (segundo as convenções do nível RT):  
ULA dedicada que realiza o cálculo de maneira paralela,  
evita ocorrência de **overflow** e tem custo mínimo



Pontos Positivos:

- Jamais ocorre overflow.
- Este esquemático deixa claro como é gerado o bit mais significativo da saída dos somadores.
- Somadores dimensionados de modo a economizar recursos (2 somadores p/ números com 8 bits e 1 somador para números de 9 bits) e minimizar o atraso crítico!

# Temporização e Análise de Timing

---

## Análise de *Timing*\*

Assumindo que os componentes da ULA dedicada vista no slide anterior tenham as características temporais mostradas na tabela abaixo, realize a análise de *timing*\*

| Componente                             | Característica | Símbolo | Valor   |
|----------------------------------------|----------------|---------|---------|
| Registradores R1, R2, R3               | tempo de setup | tsu     | 1 ns    |
| Registradores R1, R2, R3               | tempo de hold  | th      | 0,5 ns  |
| Registradores R1, R2, R3               | tempo de carga | tco     | 1 ns    |
| Somador completo ( <i>full adder</i> ) | atraso         | tds     | 0,25 ns |

\* Análise de *timing* significa determinar o(s) caminho(s) crítico(s) e o atraso crítico.

# Temporização e Análise de Timing

## Análise de *Timing*

Exemplo:  $S \leftarrow A + B + C + D$

A análise inicia assumindo-se uma primeira borda de relógio ( $t_0$ ) aplicada a A, B, C e D



# Temporização e Análise de Timing

## Análise de *Timing*

Exemplo:  $S \leftarrow A + B + C + D$



# Temporização e Análise de Timing

## Análise de *Timing*

Exemplo:  $S \leftarrow A + B + C + D$



# Temporização e Análise de Timing

## Análise de *Timing*

Exemplo:  $S \leftarrow A + B + C + D$



# Temporização e Análise de Timing

## Análise de *Timing*

Exemplo:  $S \leftarrow A + B + C + D$



# Temporização e Análise de Timing

## Análise de *Timing*

Exemplo:  $S \leftarrow A + B + C + D$

Quantos Caminhos Críticos há?

Considerando o tempo de setup do registrador S



# Temporização e Análise de Timing

## Análise de *Timing*

Exemplo:  $S \leftarrow A + B + C + D$

Todos os 16 caminhos são críticos (com mesmo atraso)

A → soma1 → soma3 → S

A → cout1 → soma3 → S

A → soma1 → cout3 → S

A → cout1 → cout3 → S

B → soma1 → soma3 → S

B → cout1 → soma3 → S

B → soma1 → cout3 → S

B → cout1 → cout3 → S

C → soma2 → soma3 → S

C → cout2 → soma3 → S

C → soma2 → cout3 → S

C → cout2 → cout3 → S

D → soma2 → soma3 → S

D → cout2 → soma3 → S

D → soma2 → cout3 → S

D → cout2 → cout3 → S



Logo, atraso crítico  
= D = 6,25 ns

# Temporização e Análise de Timing

## Análise de *Timing*

Exemplo:

$$S \leftarrow A + B + C + D$$

Calculando o atraso crítico diretamente a partir do(s) caminho(s) crítico(s):

$$\begin{aligned} D = T &= \max\{ t_{co_A}, t_{co_B}, t_{co_C}, t_{co_D} \} + \\ &t_{d_{somador8bits}} + t_{d_{somador9bits}} + t_{su_S} = \\ &= 1 + 8 \times 0,25 + 9 \times 0,25 + 1 = 6,25 \text{ ns} \end{aligned}$$



**sendo  $T \geq D$**



# Leituras da Semana

---

VAHID, Frank. Digital Design with RTL Design, VHDL and Verilog. 2nd Edition. Wiley, 2010.

ou

VAHID, Frank. Sistemas Digitais: projeto, otimização e HDLs. Porto Alegre: Bookman, 2008. (ISBN 978-85-7780-190-9)



**Latches e Flip-flops:** Seções 3.1, 3.2 e 3.5.

**Banco de Registradores:** Seção 4.10

**Memórias:** Seção 5.6