Lezione laboratorio SPIM
|
|
- Renata Marino
- 5 anni fa
- Visualizzazioni
Transcript
1 Lezione laboratorio SPIM Uso di XSPIM Uso di PCSPIM Esercizio laboratorio 1 Cos è SPIM e cosa fa? SPIM è un simulatore che esegue programmi per le architetture MIPS R2000/R3000 SPIM può leggere ed assemblare programmi scritti in linguaggio assembly MIPS SPIM contiene un debugger che consente di analizzare passo_passo il funzionamento dei programmi Utilizzeremo SPIM per provare programmi in linguaggio assembly 2 1
2 Perché utilizzare un simulatore MIPS? Controllo degli errori Meccanismi di debug Possibilità di utilizzare MIPS su diverse piattaforme ( Unix, Linux, Windows ) A casa con Windows o Linux su macchine Intel, in laboratorio con Linux su macchine Intel L alternativa più comune (assembly 80X86) è molto complessa e non adatta ad un corso universitario 3 Dove trovare SPIM? Esistono due versioni di SPIM Linux/Unix (xspim) Windows (pcspim) Per installare SPIM nella versione Windows Scaricare pcspim.exe (file di installazione) Fare doppio clic su pcspim.exe Seguire le indicazioni 4 2
3 XSPIM Scrivete xspim & e apparirà la schermata dell interfaccia grafica di XSPIM Formata da cinque sezioni... 5 Sezione Registri e Bottoni di controllo 6 3
4 La sezione Register Display Alla sommità si trova la sezione register display In essa sono visualizzati i valori di tutti i registri contenuti nella CPU e nella FPU di MIPS Vi sono 32 registri generali, 32 registri floating point e alcuni registri speciali (PC, LO, HI,...) Tutti i valori contenuti nei registri sono di norma rappresentati nel sistema numerico esadecimale (base 16) Il contenuto dei registri è aggiornato ogni volta che il programma si ferma (stops running) 7 I bottoni di controllo La sezione successiva contiene i bottoni di controllo che consentono di attivare i comandi MIPS : QUIT: Termina l esecuzione del programma LOAD: Carica un nuovo programma MIPS. Deve essere stato scritto al di fuori di MIPS con un qualche Editor di testo (es.: JCreator in MS Windows) RELOAD: Ricarica il programma. E utilizzato quando si vuole ri_eseguire un programma dopo aver apportato delle modifiche al codice RUN: Esegue il programma caricato 8 4
5 I bottoni di controllo STEP: Esegue passo-passo il codice, una istruzione alla volta; questa funzionalità è utile per il debugging del programma CLEAR: Usato per il reset dei valori dei registri e/o di locazioni di memoria. (clear/registerregister oppure clear / memory & register) SET VALUE: Usato per assegnare valori ai registri utilizzati nel programma 9 I bottoni di controllo BREAKPOINTS: Usato per set/delete/list di breakpoints; i punti di breakpoints vengono fissati specificando l indirizzo di locazioni di memoria, quando il programma verrà esguito, XSPIM sospenderà l esecuzione alla istruzione specificata TERMINAL: Per passare alla console window di SPIM; sulla console vengono visualizzati i messaggi in output, e in essa viene digitato ogni input richiesto dal programma, inoltre la console rappresenta il luogo ove avviene ogni interazione con l utente 10 5
6 Il Text Segments indirizzo di di memoria della della istruzione codice codicemacchina simbolico (pseudo istruzioni espanse e label label sostituite con con numeri) istruzioni originarie del del programma istruzioni tradotte in in codice codicemacchina binario binario dopo dopopunto-e-virgola il ilnumero di di riga rigae codice codiceassembly originario 11 Il Text Segment La sezione text segments visualizza le istruzioni assembly del programma assieme al codice macchina corrispondente (che SPIM carica in memoria quando inizia l esecuzione) Il primo numero a sinistra (tra parentesi quadre) è l indirizzo (esadecimale) di memoria in cui si trova l istruzione macchina Il secondo numero è la codifica numerica binaria dell istruzione (in esadecimale) Il terzo elemento è la rappresentazione simbolica (mnemonica) dell istruzione macchina 12 6
7 Il Text Segment Tutto ciò che segue il punto e virgola è l istruzione originaria del file assembly da cui ha avuto origina l istruzione/i macchina Alle volte la parte della riga che segue l'istruzione macchina è vuota; ciò significa che l istruzione macchina è stata prodotta come parte della traduzione di una pseudo-istruzione 13 Il Data Segment Messaggi di di SPIM SPIM 14 7
8 Il Data Segment La sezione Data Segments visualizza la porzione di memoria che è usata per la memorizzazione dei dati La parte intestata KERNEL contiene dati del sistema operativo che vengono caricati non appena SPIM inizia la propria esecuzione e prima che il codice dell utente sia caricato La sezione più in basso visualizza i messaggi emessi da SPIM 15 Struttura di un programma SPIM (1).data var:.word 15 buf:.space 4.text Dichiara che le linee che seguono contengono dati da inserire nel data segment Alloca lo spazio per una singola parola e in essa memorizza il valore (15) Alloca lo spazio vuoto (contenente garbage) di dimensione 4 (bytes) Dichiara che le linee che seguono sono istruzioni assembly, text segment.globl main Dichiara la label main global, cioè accessibile dall esterno (da altri file) 16 8
9 Struttura di un programma SPIM (2) main: la $t0, var Il programma inizia dalla label main. var punta alla parola precedente inizializzata con il valore 15. La pseudo_istruzione carica l indirizzo rappresentato dalla label var nel registro $t0 lw $s0, 0($t0) Carica in $s0 il valore di var : 15 la $t1, buf sw $s0, 0($t1) $t1 punta allo spazio di 4 byte allocato in precedenza Il valore di $s0 viene scritto nello spazio di 4 byte. 17 PCSpim 18 9
10 PCSpim finestra principale 19 PCSpim menu File Open 20 10
11 PCSpim menu File Open 21 PCSpim menu Simulatore 22 11
12 PCSpim Simulator Go 23 PCSpim Console 24 12
13 PCSpim Simulator Setting C:\Programmi\PCSpim\trap.handler 25 PCSpim Window Clear 26 13
14 Esercizio laboratorio 27 Esercizio laboratorio Dato in memoria centrale un vettore di integer (a 32 bit), dichiarato mediante le direttive.data e.word, di dimensione 10, di nome "vet", inizializzato con la seq. 10, 20, 30, 40, 50, 60,70, 80, 90, 100 Scrivere il codice assembly per leggere un intero i e stampare l elemento i-esimo del vettore, vet[i] 28 14
15 Esercizio laboratorio (1) # DEFINIZIONI COSTANTI SIMBOLICHE # print_int = 1 print_string = 4 read_int = 5 read_string = 8 sbrk = 9 exit = 10 # DATI ##################.data vet:.word 10, 20, 30, 40, 50.word 60, 70, 80, 90, 100 str1: asciiz "digita un numero da 0 a 9 : " 29 Esercizio laboratorio (2) # CODICE ############## # Uso dei registri # $t0 - temp/contatore # $t1 - addr elemento del vettore # $t2 - valore da memorizzare # $t3 - contatore # $t4 - temp # $t8 - indirizzo di base del vettore "vet" # $t9 - valore max (10) 30 15
16 Esercizio laboratorio (3) # MAIN ###################.text main: # Inizializzazione registri la $t8, vet # carico nel registro $t8 # l'indirizzo della base del vettore # stampa stringa di prompt li $v0, print_string la $a0, str1 syscall # lettura di "i" li $v0, read_int syscall move $t0, $v0 31 Esercizio laboratorio (4) # calcolo indirizzo dell'elemento i-esimo add $t0, $t0, $t0 #$t0 = 2*i add $t0, $t0, $t0 #$t0 = 4*i add $t1, $t8, $t0 #$t1 = indiriz.di vet[i] # stampa l'elemento i-esimo lw $a0, 0($t1) #$a0 = vet[i] # versione con indice "lw $a0,vet($t0)" li $v0, print_int syscall esci: li $a0, 0 li $v0, exit # FINE syscall 32 16
17 Laboratorio 4 - MIPS 1 - Esercizio SPIM Sia dato in memoria centrale un vettore di integer (a 32 bit), dichiarato mediante le direttive.data e.word, di dimensione 10, di nome "vet" e inizializzato con la sequenza di numeri: 10, 20, 30, 40, 50, 60,70, 80, 90, 100.data vet:.word 10, 20, 30, 40, 50.word 60, 70, 80, 90, 100 A lezione si è visto il codice assembly eseas1.s che legge un valore di indice i e stampa l elemento del vettore vet[i]. Come esercitazione sviluppare i seguenti punti: 1) scaricare il codice dell' esercizio visto a lezione eseas1.s ; 2) far girare il codice mediante il simulatore SPIM; 3) fare un reload del codice, eseguirlo con il comando step, ed osservare come si modificano i valori dei registri; 33 Laboratorio 4 - MIPS 1 - Esercizio SPIM 4) introdurre nuove istruzioni in modo da visualizzare tutti gli elementi del vettore mediante un ciclo senza terminazione; 5) inserire una condizione di terminazione; 6) inserire un fine riga ("eol") dopo ogni elemento del vettore (usare la syscall print_string applicata alla stringa.asciiz "\n ); 7) inserire un "eol" ogni 2 elementi; 8) sommare tutti gli elementi del vettore nella variabile di memoria sum e stampare il risultato; 9) facoltativo: fare il reverse del vettore 34 17
18 Laboratorio 4 - MIPS 1 - Esercizio SPIM Nello sviluppare l'esercizio si suggerisce: di seguire l'ordine con cui sono esposte le operazioni da realizzare; di verificare il funzionamento del codice passo-passo mediante la funzione di avanzamento single step dello SPIM, osservando attentamente il modificarsi dei registri del processore e delle locazioni di memoria coinvolte dalla esecuzione delle singole istruzioni; di evitare (!!!) di lanciare un run per provare il codice del punto 4 (ciclo senza terminazione)! usare invece l'avanzamento a step
Calcolatori Elettronici
Calcolatori Elettronici SPIM Francesco Lo Presti Rielaborate da Salvatore Tucci SPIM q Simulatore che esegue programmi assembler per architetture RISC MIPS R2000/R3000 Legge programmi in assembler MIPS
DettagliIl simulatore SPIM SPIM
Il simulatore SPIM Architetture dei Calcolatori (lettere A-I) SPIM SPIM: un simulatore per eseguire programmi assembler scritti per processori MIPS32 Download e materiale relativo alla pagina Web http://www.cs.wisc.edu/~larus/spim.html
DettagliArchitetture dei Calcolatori (Lettere. Installazione di SPIM. Interfaccia Grafica
SPIM Architetture dei Calcolatori (Lettere A-I) SPIM Ing.. Francesco Lo Presti Simulatore che esegue programmi assembler per architetture RISC MIPS R2000/R3000 Legge programmi in assembler MIPS e li traduce
Dettagli[http://www.di.univaq.it/muccini/labarch]
[http://www.di.univaq.it/muccini/labarch] Modulo di Laboratorio di Architettura degli Elaboratori Corso di Architettura degli Elaboratori con Laboratorio Docente: H. Muccini Lecture 3: Introduzione a SPIM
DettagliIndirizzamento, lettura e scrittura della memoria
Università degli Studi di Milano Corso di Laurea in Informatica, A.A. 2018-2019 Indirizzamento, lettura e scrittura della memoria Turno A Nicola Basilico Dipartimento di Informatica Via Celoria 18-20133
DettagliAssembly III SPIM: un ambiente di simulazione MIPS
Architettura degli Elaboratori e delle Reti Lezione 13 Assembly III SPIM: un ambiente di simulazione MIPS Proff. A. Borghese, F. Pedersini Dipartimento di Scienze dell Informazione Università degli Studi
DettagliL ambiente di simulazione SPIM
Architettura degli Elaboratori e delle Reti Lezione 14 L ambiente di simulazione SPIM Proff. A. Borghese, F. Pedersini Dipartimento di Scienze dell Informazione Università degli Studi di Milano L 14 1/20
DettagliSystem calls. Università degli Studi di Milano Corso di Laurea in Informatica, A.A Homepage del corso
Università degli Studi di Milano Corso di Laurea in Informatica, A.A. 2017-2018 System calls Homepage del corso Turno A Nicola Basilico Dipartimento di Informatica Via Comelico 39/41-20135 Milano (MI)
DettagliSystem calls. Università degli Studi di Milano Corso di Laurea in Informatica, A.A Homepage del corso
Università degli Studi di Milano Corso di Laurea in Informatica, A.A. 2017-2018 System calls Homepage del corso Turno A Nicola Basilico Dipartimento di Informatica Via Comelico 39/41-20135 Milano (MI)
DettagliArchitettura degli Elaboratori II - Laboratorio
Pietro Codara http://homes.di.unimi.it/ dantona/arch Prima lezione 24 Ottobre 2012 Informazioni pratiche Lezioni frontali: Mer 24 Ottobre 2012, 18.30-21.30, Aula 200 (via Celoria) Ven 26 Ottobre 2012,
DettagliMemoria: lettura, scrittura e indirizzamento
Memoria: lettura, scrittura e indirizzamento Ultimo aggiornamento: 27/3/2015 Università degli studi di Milano matteo.re@unimi.it https://homes.di.unimi.it/re/arch2-lab-2015-2016.html Organizzazione della
DettagliMacchina di Riferimento: argomenti
Macchina di Riferimento: argomenti L'architettura di una macchina MIPS Organizzazione della memoria I registri della CPU L'esecuzione dei programmi Il ciclo fetch-execute Il simulatore SPIM 1 Architettura
DettagliLinguaggio macchina: utilizzo di costanti, metodi di indirizzamento
Architetture degli Elaboratori e delle Reti Lezione 17 Linguaggio macchina: utilizzo di costanti, metodi di indirizzamento Proff. A. Borghese, F. Pedeini Dipaimento di Scienze dell Informazione Univeità
Dettagli26 April CHIAMATA A PROCEDURE PROCEDURE ANNIDATE PROCEDURA RICORSIVE I. Frosio
CHIAMATA A PROCEDURE PROCEDURE ANNIDATE PROCEDURA RICORSIVE I. Frosio SOMMARIO Procedure di sistema (syscall) / direttive Chiamata a procedura semplice Chiamata a procedure intermedia Procedure ricorsive
DettagliIl linguaggio assembly
Il linguaggio assembly Direttive Chiamate di sistema (system call) Esempi 1 Direttive Le direttive (data layout directives) danno delle indicazioni all'assemblatore sul contenuto di un file (istruzioni,
DettagliModalità di indirizzamento
Modalità di Indirizzamento + Programmi Architettura degli Elaboratori e delle Reti Turno I Alberto Borghese Università degli Studi di Milano Dipartimento di Scienze dell Informazione email: borghese@dsi.unimi.it
DettagliIndirizzamento, lettura e scrittura della memoria
Università degli Studi di Milano Corso di Laurea in Informatica, A.A. 2017-2018 Indirizzamento, lettura e scrittura della memoria Homepage del corso Turno A Nicola Basilico Dipartimento di Informatica
DettagliLaboratorio di Architettura degli Elaboratori
Laboratorio di Architettura degli Elaboratori Dott. Massimo Tivoli Introduzione a MARS: interfaccia, struttura di un programma, gestione dell input L assemblatore e simulatore MARS Permette di eseguire
DettagliUniversità degli Studi di Roma La Sapienza Architettura degli elaboratori II
Università degli Studi di Roma La Sapienza Architettura degli elaboratori II Architettura degli elaboratori II Indice degli argomenti Le istruzioni assembly Categorie di istruzioni assembly Istruzioni
DettagliIl linguaggio assembly
Il linguaggio assembly PH 2.3 (continua) 1 Argomenti Organizzazione della memoria Istruzioni di trasferimento dei dati Array Istruzioni logiche 2 1 La memoria del MIPS I contenuti delle locazioni di memoria
DettagliLaboratorio
Laboratorio 21-10-2008 CPUSIM PARTE1 Preparazione ambiente di lavoro In questa lezione iniziamo ad utilizzare il programma CPUSim, che permette di simulare l esecuzione di programmi assembler da parte
DettagliSystem Calls, Register Spilling
System Calls, Register Spilling Ultimo aggiornamento: 8/4/2016 UNIVERSITÀ DEGLI STUDI DI MILANO nicola.basilico@unimi.it http://basilico.di.unimi.it/ Esercizio 3.1 Eseguire il seguente codice assembly
DettagliL ambiente di simulazione SPIM
Architettura degli Elaboratori e delle Reti Lezione 14 L ambiente di simulazione SPIM Proff. A. Borghese, F. Pedersini Dipartimento di Scienze dell Informazione Università degli Studi di Milano L 14 1/28
DettagliCPUSim. Laboratorio 30/11/2016
CPUSim Laboratorio 30/11/2016 Tommaso Padoan e-mail: padoan@math.unipd.it CPUsim Scaricare il simulatore: www.math.unipd.it/~sperduti/architettura1.html scorrere fino a sezione Simulatori, aprire la pagina
Dettagli25 March : LABORATORIO 02 ISTRUZIONI DI LETTURA E SCRITTURA DELLA MEMORIA, ARRAY REGISTER SPILLING D I/O DIRETTIVE ASSEMBLY. I.
03: LABORATORIO 02 25 March 2011 ISTRUZIONI DI LETTURA E SCRITTURA DELLA MEMORIA, ARRAY REGISTER SPILLING D I/O DIRETTIVE ASSEMBLY I. Frosio 1 SOMMARIO Istruzioni di lettura e scrittura della memoria,
DettagliArchitettura degli Elaboratori Lez. 3 ASM: Strutture di controllo. Prof. Andrea Sterbini
Architettura degli Elaboratori Lez. 3 ASM: Strutture di controllo Prof. Andrea Sterbini sterbini@di.uniroma1.it Argomenti Argomenti della lezione - Il simulatore MARS - Le strutture di controllo - Esempi
DettagliUn quadro della situazione. Lezione 14 Il Set di Istruzioni (2) Dove siamo nel corso. I principi di progetto visti finora. Cosa abbiamo fatto
Un quadro della situazione Lezione 14 Il Set di Istruzioni (2) Vittorio Scarano Architettura Corso di Laurea in Informatica Università degli Studi di Salerno Input/Output Sistema di Interconnessione Registri
DettagliLaboratorio di Architettura degli Elaboratori LabArch 2006 Secondo Quadimestre, a.a Docente: H. Muccini
[http://www.di.univaq.it/muccini/labarch] Laboratorio di Architettura degli Elaboratori LabArch 2006 Secondo Quadimestre, a.a. 2005-2006 Docente: H. Muccini Lecture 2: Prime Istruzioni -Concetti Fondamentali
DettagliCalcolatori Elettronici A a.a. 2008/2009
Calcolatori Elettronici A a.a. 2008/2009 ISA e LINGUAGGIO ASSEMBLY MIPS ESERCIZI Massimiliano Giacomin ESERCIZIO Utilizzando la green card, tradurre in linguaggio macchina le due istruzioni in assembly
DettagliLe costanti Le modalità di indirizzamento L assembly del MIPS
Le costanti Le modalità di indirizzamento L assembly del MIPS Prof. Alberto Borghese Dipartimento di Scienze dell Informazione borghese@dsi.unimi.it Università degli Studi di Milano 1/45 Sommario Le costanti
DettagliIl linguaggio del calcolatore: linguaggio macchina e linguaggio assembly
Il linguaggio del calcolatore: linguaggio macchina e linguaggio assembly Percorso di Preparazione agli Studi di Ingegneria Università degli Studi di Brescia Docente: Massimiliano Giacomin Richiamo sull
DettagliDal sorgente all eseguibile I programmi Assembly
Dal sorgente all eseguibile I programmi Assembly Prof. Alberto Borghese Dipartimento di Scienze dell Informazione borghese@dsi.unimi.it Università degli Studi di Milano 1/46 Sommario Dal linguaggio ad
DettagliUn quadro della situazione. Lezione 15 Il Set di Istruzioni (2) Le operazioni e gli operandi. Dove siamo nel corso. Cosa abbiamo fatto
Un quadro della situazione Lezione 15 Il Set di Istruzioni (2) Vittorio Scarano Architettura Corso di Laurea in Informatica Università degli Studi di Salerno Input/Output Sistema di Interconnessione Registri
DettagliUniversità degli Studi di Roma La Sapienza
Università degli Studi di Roma La Sapienza Architettura degli elaboratori II Introduzione ai concetti ed al simulatore SPIM Andrea Sterbini e Franco Liberati Tratto da dispense di Alberto Montresor, Riccardo
DettagliArchitettura degli elaboratori Lezione di laboratorio 04/03/15. Dr. Francesco Giacomini e Dr. Matteo Manzali Università degli Studi di Ferrara
Architettura degli elaboratori Lezione di laboratorio 04/03/15 Dr. Francesco Giacomini e Dr. Matteo Manzali Università degli Studi di Ferrara Informazioni generali Durante la parte di laboratorio siete
DettagliArchitettura dei calcolatori e sistemi operativi. Architettura MIPS e set istruzioni Capitolo 2 P&H
Architettura dei calcolatori e sistemi operativi Architettura MIPS e set istruzioni Capitolo 2 P&H Instruction Set Architecture ISA Linguaggio assemblatore e linguaggio macchina ISA processore MIPS Modello
DettagliUn altro tipo di indirizzamento. L insieme delle istruzioni (3) Istruz. di somma e scelta con operando (2) Istruzioni di somma e scelta con operando
Un altro tipo di indirizzamento L insieme delle istruzioni (3) Architetture dei Calcolatori (lettere A-I) Tipi di indirizzamento visti finora Indirizzamento di un registro Indirizzamento con registro base
DettagliArchitettura degli. Assemblatore Nomenclatura MARS. Dott. Franco Liberati
Architettura degli Elaboratori Assemblatore Nomenclatura MARS Dott. Franco Liberati Assemblatore Introduzione Argomenti della lezione Nomenclatura Registri Istruzioni e pseudoistruzioni Architettura degli
DettagliAssembler di Spim. Assembler di SPIM. Struttura di un programma assembler. Direttive
Assembler di Spim Assembler di SPIM Il programma è organizzato in linee Ogni linea può contenere un commento che parte dal carattere # e si estende fino alla fine della linea Ogni linea che non sia bianca
DettagliLezione4: MIPS e Istruzioni (1 Parte)
Architettura degli Elaboratori Lezione4: MIPS e Istruzioni (1 Parte) Michele Nappi mnappi@unisa.it http://www.biplab.unisa.it/ Alcune slide di questa lezione sono prodotte dal Prof. Luigi Palopoli AGENDA
DettagliLaboratorio di Architettura degli Elaboratori
Laboratorio di Architettura degli Elaboratori Dott. Massimo Tivoli Set di istruzioni del MIPS32: istruzioni aritmetiche e di trasferimento Istruzioni (Alcune) Categorie di istruzioni in MIPS Istruzioni
DettagliLaboratorio di Architettura degli Elaboratori LabArch 2006 Secondo Quadimestre, a.a Docente: H. Muccini
[http://www.di.univaq.it/muccini/labarch] Laboratorio di Architettura degli Elaboratori LabArch 2006 Secondo Quadimestre, a.a. 2005-2006 Docente: H. Muccini Lecture 09: - Modi di indirizzamento del MIPS
DettagliLe procedure ricorsive Come eseguire un programma. Architettura degli Elaboratori e delle Reti, Turno I
Le procedure ricorsive Come eseguire un programma Architettura degli Elaboratori e delle Reti, Turno I Alberto Borghese Università degli Studi di Milano Dipartimento di Scienze dell Informazione email:
DettagliIntro ai tools di MARS
Università degli Studi di Milano Corso di Laurea in Informatica, A.A. 2017-2018 Intro ai tools di MARS Homepage del corso Turno A Nicola Basilico Dipartimento di Informatica Via Comelico 39/41-20135 Milano
DettagliEsercitazione 06 Progettazione di una CPU RISC-V
Esercitazione 06 Progettazione di una CPU RISC-V Gianluca Brilli gianluca.brilli@unimore.it 04/06/19 ARCHITETTURA DEI CALCOLATORI 1 Overview In questa esercitazione andremo a progettare una semplice architettura
DettagliLezione 15 Il Set di Istruzioni (1)
Lezione 15 Il Set di Istruzioni (1) Vittorio Scarano Architettura Corso di Laurea in Informatica Università degli Studi di Salerno Un quadro della situazione Input/Output Sistema di Interconnessione Registri
DettagliInformazioni varie. Lezione 18 Il Set di Istruzioni (5) Dove siamo nel corso. Un quadro della situazione
Informazioni varie Lezione 18 Il Set di Istruzioni (5) Vittorio Scarano Architettura Corso di Laurea in Informatica Università degli Studi di Salerno La lezione di martedì 20 maggio (9-12) non si tiene
DettagliLezione 20. della CPU MIPS. Prof. Federico Pedersini Dipartimento di Informatica Università degli Studi di Milano
Architettura degli Elaboratori Lezione 20 ISA (Instruction Set Architecture) della CPU MIPS Prof. Federico Pedersini Dipartimento di Informatica Università degli Studi di Milano L16-20 1/29 Linguaggio
DettagliEsercizi per il recupero del debito formativo:
ANNO SCOLASTICO 2005/2006 CLASSE 4 ISC Esercizi per il recupero del debito formativo: Facendo esclusivamente uso delle istruzioni del linguaggio macchina mnemonico del microprocessore INTEL 8086 viste
DettagliArchitettura degli Elaboratori
Architettura degli Elaboratori Linguaggio macchina e assembler (caso di studio: processore MIPS) slide a cura di Salvatore Orlando, Marta Simeoni, Andrea Torsello Architettura degli Elaboratori 1 1 Istruzioni
DettagliUniversità degli Studi di Roma La Sapienza
Università degli Studi di Roma La Sapienza Architettura degli elaboratori II Introduzione ai concetti ed al simulatore SPIM Indice degli argomenti Introduzione Assembler, compilatore, linker, programma
DettagliCorso di Architettura (Prof. Scarano) 10/05/2002
Lezione 0 Il Set di Istruzioni (6) Vittorio Scarano Architettura Corso di Laurea in Informatica Università degli Studi di Salerno Le procedure Prima della chiamata di una procedura In ogni linguaggio di
DettagliLecture 2: Prime Istruzioni
[http://www.di.univaq.it/muccini/labarch] Modulo di Laboratorio di Architettura degli Elaboratori Corso di Architettura degli Elaboratori con Laboratorio Docente: H. Muccini Lecture 2: Prime Istruzioni
Dettagli8 March : LABORATORIO 01 ISA & ASSEMBLY REGISTER FILE INTRODUZIONE A SPIM OPERAZIONI ARITMETICHE. I. Frosio
01: LABORATORIO 01 ISA & ASSEMBLY REGISTER FILE INTRODUZIONE A SPIM OPERAZIONI ARITMETICHE I. Frosio 1 SOMMARIO ISA & Linguaggio macchina Assembly I registri Istruzioni aritmetiche Obiettivo PCSpim Operazioni
DettagliIntroduzione al linguaggio assembly
Corso di Calcolatori Elettronici I Introduzione al linguaggio assembly ing. Alessandro Cilardo Corso di Laurea in Ingegneria Biomedica Riepilogo PC R 0 MA R 1 R 2 R 3 IR MB read memoria O 1 O 2 op ALU
DettagliIstruzioni e linguaggio macchina
Istruzioni e linguaggio macchina I linguaggi macchina sono composti da istruzioni macchina, codificate in binario, con formato ben definito processori diversi hanno linguaggi macchina simili scopo: massimizzare
DettagliLinguaggio Assembly e linguaggio macchina
Architettura degli Elaboratori e delle Reti Lezione 11 Linguaggio Assembly e linguaggio macchina Proff. A. Borghese, F. Pedersini Dipartimento di Scienze dell Informazione Università degli Studi di Milano
DettagliLinguaggio Assembly e linguaggio macchina
Architettura degli Elaboratori e delle Reti Lezione 11 Linguaggio Assembly e linguaggio macchina Proff. A. Borghese, F. Pedersini Dipartimento di Scienze dell Informazione Università degli Studi di Milano
DettagliLezione 20. Assembly MIPS: Il set istruzioni, strutture di controllo in Assembly
Architettura degli Elaboratori Lezione 20 Assembly MIPS: Il set istruzioni, strutture di controllo in Assembly Prof. F. Pedersini Dipartimento di Scienze dell Informazione Università degli Studi di Milano
DettagliU"lizzo della memoria (Indirizzamento, le2ura, scri2ura) Dire8ve Assembler in SPIM
U"lizzo della memoria (Indirizzamento, le2ura, scri2ura) Dire8ve Assembler in SPIM nicola.basilico@unimi.it http://homes.di.unimi.it/basilico/teaching/ Organizzazione della memoria Cosa con"ene la memoria?
DettagliA c r h c i h te t t e t t u t r u a r d g e li el e abo b ra r t a o t ri Assemblatore
Architettura degli elaboratori Assemblatore ARGOMENTI DELLA LEZIONE Compilatore Assemblatore Collegatore (linker) Caricatore (loader) Architettura degli elaboratori Aseemblatore L esecuzione di un programma
DettagliPrincipi operativi dei computer. Capitolo 7 Fluency Conoscere e usare l informatica
Principi operativi dei computer Capitolo 7 Fluency Conoscere e usare l informatica I soliti sospetti Processore Sistema operativo Software Istruzioni Ciclo macchina Memoria Hardware componente Com è fatto
DettagliArchitettura degli Elaboratori
Architettura degli Elaboratori Linguaggio macchina e assembler (caso di studio: processore MIPS) slide a cura di Salvatore Orlando, Andrea Torsello, Marta Simeoni " Architettura degli Elaboratori 1 1 Istruzioni
DettagliDal sorgente all eseguibile I programmi Assembly. Prof. Alberto Borghese Dipartimento di Scienze dell Informazione
Dal sorgente all eseguibile I programmi Assembly Prof. Alberto Borghese Dipartimento di Scienze dell Informazione alberto.borghese@unimi.it Riferimenti sul Patterson: Cap. 2.10 + Appendice B, tranne B.7
DettagliDal sorgente all eseguibile I programmi Assembly. Prof. Alberto Borghese Dipartimento di Scienze dell Informazione
Dal sorgente all eseguibile I programmi Assembly Prof. Alberto Borghese Dipartimento di Scienze dell Informazione alberto.borghese@unimi.it Riferimenti sul Patterson: Cap. 2.10 + Appendice B, tranne B.7
DettagliCorso di Architettura (Prof. Scarano) 09/04/2002
Corso di Architettura (Prof. Scarano) 09/0/2002 Un quadro della situazione Lezione 15 Il Set di Istruzioni (1) Vittorio Scarano Architettura Corso di Laurea in Informatica Università degli Studi di Salerno
DettagliLinguaggio Assembly e linguaggio macchina
Architettura degli Elaboratori e delle Reti Lezione 11 Linguaggio Assembly e linguaggio macchina Proff. A. Borghese, F. Pedersini Dipartimento di Scienze dell Informazione Università degli Studi di Milano
DettagliLezione 20. della CPU MIPS. Prof. Federico Pedersini Dipartimento di Informatica Università degli Studi di Milano
Architettura degli Elaboratori Lezione 20 ISA (Instruction Set Architecture) della CPU MIPS Prof. Federico Pedersini Dipartimento di Informatica Università degli Studi di Milano L16-20 1/29 Linguaggio
DettagliLaboratorio di Architetture degli Elaboratori II (A.A )
Laboratorio di Architetture degli Elaboratori II (A.A. 2015-2016) Matteo Re, matteo.re@unimi.it [cognomi G-Z] (Nicola Basilico, [cognomi A-D]) Ufficio S210, Dipartimento di Informatica, Via Comelico 39/41-20135
DettagliLezione 6 programmazione in Java
Lezione 6 programmazione in Java Nicola Drago drago@sci.univr.it Dipartimento di Informatica Università di Verona Anteprima Le costanti I vettori Cos è un vettore Come si usa I vari tipi di vettori Esempi
DettagliStringhe di caratteri
Stringhe di caratteri PH 2.8 1 Gestione dei caratteri Ogni carattere è rappresentato univocamente mediante un codice numerico rappresentabile usando un byte (codice ASCII) MIPS fornisce le istruzioni lb
DettagliModi di indirizzamento. Indicano come accedere all operando di interesse dell istruzione. Il MIPS ha 5 modi di indirizzamento:
Modi di indirizzamento Indicano come accedere all operando di interesse dell istruzione. Il MIPS ha 5 modi di indirizzamento: immediato (immediate) slti $1,$2,100 registro (register) slti $1,$2,100 base/spiazzamento
DettagliISA & Assembly Register file Introduzione a SPIM Operazioni aritme-che
ISA & Assembly Register file Introduzione a SPIM Operazioni aritme-che Laboratorio Massimo Marchi, marchi@di.unimi.it 24 ore di esercitazione Modalità di esame: realizzazione e discussione di un proge?o
DettagliEsercitazione 1 Codifica e Rappresentazione dell Informazione Istruzioni Assembly MIPS
Esercitazione 1 Codifica e Rappresentazione dell Informazione Istruzioni Assembly MIPS Claudia Raibulet raibulet@disco.unimib.it Codifica e Rappresentazione dell Informazione Informazioni Generali (I)
DettagliLezione 12. Assembly II. Set di Istruzioni MIPS Strutture di controllo in Assembly
Architettura degli Elaboratori e delle Reti Lezione 12 Assembly II Set di Istruzioni MIPS Strutture di controllo in Assembly Proff. A. Borghese, F. Pedersini Dipartimento di Scienze dell Informazione Università
DettagliLinguaggio assembler e linguaggio macchina (caso di studio: processore MIPS)
Linguaggio assembler e linguaggio macchina (caso di studio: processore MIPS) Salvatore Orlando Arch. Elab. - S. Orlando 1 Livelli di astrazione Scendendo di livello, diventiamo più concreti e scopriamo
DettagliIl linguaggio Assembly. Architettura degli Elaboratori e delle Reti Turno I
Il linguaggio Assembly Architettura degli Elaboratori e delle Reti Turno I Alberto Borghese Università degli Studi di Milano Dipartimento di Scienze dell Informazione borghese@dsi.unimi.it 1 Linguaggio
DettagliEsercitazione 8 Eccezioni & Interruzioni in MIPS 32 Claudia Raibulet raibulet@disco.unimib.it Eccezioni Le eccezioni = variazioni delle condizioni normali di funzionamento della CPU Conseguenze delle eccezioni
DettagliProgrammazione A.A Architettura dei Calcolatori. ( Lezione V ) Componenti hardware e loro schema funzionale
Programmazione A.A. 2002-03 I Architettura dei Calcolatori ( Lezione V ) Componenti hardware e loro schema funzionale Prof. Giovanni Gallo Dr. Gianluca Cincotti Dipartimento di Matematica e Informatica
DettagliRappresentazione dell informazione
Rappresentazione dell informazione Codifica dei numeri Rappresentazioni in base 2, 8, 10 e 16 Rappresentazioni M+S, C1 e C2 Algoritmi di conversione di base Algoritmi di somma, moltiplicazione e divisione
DettagliMIPS Instruction Set 2
Laboratorio di Architettura 18 Maggio 2012 1 Architettura Mips 2 Chiamata a Funzione 3 Esercitazione Registri MIPS reference cards: http://refcards.com/docs/waetzigj/mips/mipsref.pdf http://www.mips.com/media/files/md00565-2b-mips32-qrc-01.01.pdf
DettagliLe etichette nei programmi. Istruzioni di branch: beq. Istruzioni di branch: bne. Istruzioni di jump: j
L insieme delle istruzioni (2) Architetture dei Calcolatori (lettere A-I) Istruzioni per operazioni logiche: shift Shift (traslazione) dei bit di una parola a destra o sinistra sll (shift left logical):
DettagliUniversità degli Studi di Cassino
Corso di Indirizzamento Pseudo istruzioni Anno Accademico Francesco Tortorella Modi di indirizzamento Indicano come accedere all operando di interesse dell istruzione. Il MIPS ha 5 modi di indirizzamento:
DettagliSOLUZIONI DELLA PROVA SCRITTA DEL CORSO DI. NUOVO E VECCHIO ORDINAMENTO DIDATTICO 28 Settembre 2006
SOLUZIONI DELLA PROVA SCRITTA DEL CORSO DI NUOVO E VECCHIO ORDINAMENTO DIDATTICO 28 Settembre 26 MOTIVARE IN MANIERA CHIARA LE SOLUZIONI PROPOSTE A CIASCUNO DEGLI ESERCIZI SVOLTI ESERCIZIO 1 (8 punti)
DettagliArchitettura degli Elaboratori II Laboratorio
Università degli Studi di Milano Corso di Laurea in Informatica, A.A. 2016-2017 Architettura degli Elaboratori II Laboratorio 2016-2017 Nicola Basilico Dipartimento di Informatica Via Comelico 39/41-20135
DettagliIL SISTEMA OPERATIVO IL SISTEMA OPERATIVO
IL SISTEMA OPERATIVO Insieme di programmi che opera al di sopra della macchina fisica, mascherandone le caratteristiche e fornendo agli utenti funzionalità di alto livello. PROGRAMMI UTENTE INTERPRETE
DettagliINFORMATICA. L informatica comprende:
Varie definizioni: INFORMATICA Scienza degli elaboratori elettronici (Computer Science) Scienza dell informazione Definizione proposta: Scienza della rappresentazione e dell elaborazione dell informazione
DettagliCOSTRUZIONE DI UN APPLICAZIONE
COSTRUZIONE DI UN APPLICAZIONE Per costruire un applicazione occorre: compilare il file (o i file se più d uno) che contengono il testo del programma (file sorgente) Il risultato sono uno o più file oggetto.
DettagliIl set istruzioni di MIPS Modalità di indirizzamento. Proff. A. Borghese, F. Pedersini
Architettura degli Elaboratori e delle Reti Il set istruzioni di MIPS Modalità di indirizzamento Proff. A. Borghese, F. Pedersini Dipartimento di Scienze dell Informazione Università degli Studi di Milano
DettagliFondamenti di Informatica
Fondamenti di Informatica Prima prova intermedia - 11 Novembre 2009 Si risolvano i seguenti esercizi. Il compitino prevede un punteggio massimo di 15/14-esimi, cui andranno sommati i punti ottenuti nel
DettagliAssembly V: Procedure annidate e recursive
Architettura degli Elaboratori e delle Reti Lezione 15 Assembly V: Procedure annidate e recursive Proff. A. Borghese, F. Pedersini Dipartimento di Scienze dell Informazione Università degli Studi di Milano
DettagliArchitettura degli Elaboratori Lez. 10 Esercizi su CPU MIPS a 1 ciclo di clock. Prof. Andrea Sterbini
Architettura degli Elaboratori Lez. 10 Esercizi su CPU MIPS a 1 ciclo di clock Prof. Andrea Sterbini sterbini@di.uniroma1.it Argomenti Argomenti della lezione - Esercizi sulla CPU MIPS a 1 colpo di clock
DettagliFondamenti di Informatica II 6. Esercitazioni Laboratorio 1
Costruzione di un file eseguibile ( build ) Fondamenti di Informatica II 6. Esercitazioni Laboratorio 1 Un editor e un word processor specializzato e usato per preparare i moduli sorgenti nel linguaggio
DettagliLezione 17 Il Set di Istruzioni (3)
Lezione 17 Il Set di Istruzioni (3) Vittorio Scarano Architettura Corso di Laurea in Informatica Università degli Studi di Salerno Organizzazione della lezione Un richiamo su: Operazioni aritmetiche (add
DettagliLezione 13: Il linguaggio assembly di LC-3
Lezione 13: Il linguaggio assembly di LC-3 Laboratorio di Elementi di Architettura e Sistemi Operativi 30 Maggio 2012 Abbiamo visto... L ISA di LC-3; Ogni istruzione è identificata da un insieme di 1 e
Dettagli