## Logika cyfrowa

## Programistyczna lista zadań nr 10

Termin: 10 maja 2020

Uwaga! Poniższe zadania należy rozwiązać przy użyciu języka SystemVerilog, sprawdzić w DigitalJS oraz wysłać w systemie Web-CAT na SKOS. Należy pamiętać, aby nazwy portów nadesłanego modułu zgadzały się z podanymi w treści zadania. Wysłany plik powinien mieć nazwę toplevel.sv. Nie przestrzeganie tych zasad będzie skutkować przyznaniem 0 punktów.

1. Zaimplementuj kalkulator obliczający wyrażenia w odwrotnej notacji polskiej, operujący na 16-bitowych liczbach ze znakiem. Do przechowywania stosu wykorzystaj pamięć RAM  $1K \times 16$  z jednym portem do odczytu i jednym portem do zapisu. Szczyt stosu przechowuj w osobnym rejestrze; w ten sposób unikniesz konieczności wykonywania dwóch odczytów pamięci w jednym cyklu zegara. Działanie układu powinno być sterowane narastającymi zboczami sygnału zegara.

Układ powinien mieć następujące wejścia i wyjścia:

- nrst zanegowane wejście resetu asynchronicznego (stan niski resetuje), rejestry out i cnt powinny być inicjowane zerami, nie należy czyścić pamięci stosu podczas resetu,
- step wejście sygnału zegara,
- d 16-bitowe wejście ładowania,
- push wejście 1-bitowe wybierające operację odłożenia wejścia na stos, znaczenie:
  - wartość wysoka odłożenie wejścia d na stos,
  - wartość niska wykonanie operacji opisanej wejściem op,
- op dwubitowe wejście wybierające operację wykonywaną gdy push=0, znaczenie:
  - 0 brak operacji,
  - 1 minus unarny (zamiana wartości na szczycie stosu na przeciwną),
  - -2 dodawanie,
  - 3 mnożenie,
- out 16-bitowe wyjście pokazujące wartość na szczycie stosu,
- cnt 10-bitowe wyjście pokazujące liczbę elementów na stosie.

W tym zadaniu nie używaj modeli bramkowych przerzutników, liczników, sumatorów ani multiplikatorów. Pamięć zaimplementuj przy użyciu tablicy SystemVeriloga.

W przypadku nieprawidłowej operacji na stosie (operacja binarna na mniej niż dwóch elementach, operacja unarna na pustym stosie, przepełnienie stosu) wartość wyjścia out może być dowolna. Jednak wyjście cnt nie powinno się zawijać. Na przykład, po próbie wykonania operacji binarnej gdy cnt=0, nowa wartość cnt musi nadal wynosić 0.

Przykładowe działanie układu jest opisane w poniższej tabeli. Wiersz t zawiera stan układu po t-tym zboczu narastającym zegara, powstały ze stanu i wartości wejść z wiersza t-1.

|   | t | d | push | op | out | cnt |
|---|---|---|------|----|-----|-----|
| Ī | 0 | 2 | 1    | X  | 0   | 0   |
|   | 1 | 3 | 1    | x  | 2   | 1   |
|   | 2 | X | 0    | 1  | 3   | 2   |
|   | 3 | x | 0    | 3  | -3  | 2   |
|   | 4 | 6 | 1    | x  | -6  | 1   |
|   | 5 | x | 0    | 2  | 6   | 2   |
|   | 6 | X | X    | X  | 0   | 1   |