IDENTIFYING DATA 2021_22
Subject (*) COMPUTADORS Code 17234107
Study programme
Grau en Enginyeria Informàtica (2010)
Cycle 1r
Descriptors Credits Type Year Period Exam timetables and dates
6 Obligatòria Segon 1Q
Modality and teaching language
Department Enginyeria Informàtica i Matemàtiques
Coordinator
ROMANÍ ALSO, SANTIAGO
E-mail pere.millan@urv.cat
carlos.soriano@urv.cat
santiago.romani@urv.cat
cristina.romero@urv.cat
victoreduardo.navas@urv.cat
Lecturers
MILLAN MARCO, PEDRO
SORIANO PROCAS, CARLOS
ROMANÍ ALSO, SANTIAGO
ROMERO TRIS, CRISTINA
NAVAS MONTENEGRO, VICTOR EDUARDO
Web http://moodle.urv.net/moodle/course/view.php?id=31532
General description and relevant information

A causa de la COVID-19, és possible que algunes classes de teoria, problemes o laboratori s'hagin de fer a distància o, si més no, amb un model mixt, és a dir, per torns, alguns alumnes podran assistir a classe i la resta seguirà la classe en línia. Aquesta proposta és orientativa, podent-se produir canvis que s'informaran a l'espai Moodle de l'assignatura.

  

DESCRIPCIÓ GENERAL DE L'ASSIGNATURA: 'Computadors' aprofundeix en l'aprenentatge de la programació a baix nivell introduïda en l'assignatura de 'Fonaments dels Computadors', centrant-se en els aspectes relacionats amb els controladors d’Entrada/Sortida, és a dir, connexió al bus i accés als registres dels controladors d’E/S, així com la sincronització de l'accés mitjançant tècniques d'enquesta i interrupció. Tots aquests conceptes s'exemplifiquen utilitzant la plataforma Nintendo® DS, que incorpora dos processadors ARM i diversos controladors interns d'E/S (pantalla, botons, temporitzadors, DMA, so, etc.).


Competències
Type A Code Competences Specific
 A7 Capacitat per definir, avaluar i seleccionar plataformes hardware i software per al desenvolupament i l’execució de sistemes, serveis i aplicacions informàtiques.
 CM9 Capacitat de conèixer, comprendre i avaluar l'estructura i arquitectura dels computadors, així com els components bàsics que els conformen.
Type B Code Competences Transversal
 B3 Capacitat per resoldre problemes amb iniciativa, presa de decisions, autonomia i creativitat. Capacitat per saber comunicar i transmetre els coneixements, habilitats i destreses de la professió d’enginyer tècnic en informàtica.
 B8 Capacitat de treballar en grup i en un entorn multilingüe i multidisciplinar.,
Type C Code Competences Nuclear

Resultats d'aprenentage
Type A Code Learning outcomes
 A7 Reforça el coneixement de l’organització i el funcionament dels subsistemes de l’estructura Von Neumann: Processador, Memòria i Entrada/Sortida.
Sap utilitzar les eines del Llenguatge Assemblador per generar programes en L.M. dels processadors ARM.
Sap enllaçar rutines escrites en Llenguatge Assemblador d'ARM amb un programa escrit en llenguatge C.
Utilitza eines de depuració per fer el seguiment dels programes escrits en L.M.
Entén la funcionalitat dels interfícies entre el computador i els dispositius perifèrics, és a dir, dels controladors d’E/ S.
Analitza els mètodes de sincronització per enquesta i per interrupció, i dissenyar rutines que utilitzin aquests mètodes de manera eficaç i eficient.
Comprèn el mètode de transferència d'informació a través de controladors d'accés directe a memòria (DMA), i dissenya rutines que utilitzin aquest mètode de manera eficaç.
Coneix altres sistemes més sofisticats per manegar les transferències d'Entrada/Sortida, basats en processadors auxiliars especialitzats.
 CM9 Reforça el coneixement de l’organització i el funcionament dels subsistemes de l’estructura Von Neumann: Processador, Memòria i Entrada/Sortida.
Entén el format de les instruccions i les dades del Llenguatge Màquina dels processadors ARM, així com saber ubicar aquesta informació dins la memòria del computador.
Analitza un conjunt significatiu d’instruccions i modes d’adreçament del L.M. dels processadors compatibles ARM.
Sap utilitzar les eines del Llenguatge Assemblador per generar programes en L.M. dels processadors ARM.
Tradueix estructures algorísmiques (seqüencials, condicionals, iteratives) a Llenguatge Assemblador d'ARM.
Converteix funcions de programes escrits en llenguatge C a l’equivalent en Llenguatge Assemblador d'ARM, és a dir, subrutines amb el pas de paràmetres i retorn de resultats, tant per valor com per referència.
Sap enllaçar rutines escrites en Llenguatge Assemblador d'ARM amb un programa escrit en llenguatge C.
Utilitza eines de depuració per fer el seguiment dels programes escrits en L.M.
Entén la funcionalitat dels interfícies entre el computador i els dispositius perifèrics, és a dir, dels controladors d’E/ S.
Analitza els mètodes de sincronització per enquesta i per interrupció, i dissenyar rutines que utilitzin aquests mètodes de manera eficaç i eficient.
Comprèn el mètode de transferència d'informació a través de controladors d'accés directe a memòria (DMA), i dissenya rutines que utilitzin aquest mètode de manera eficaç.
Coneix altres sistemes més sofisticats per manegar les transferències d'Entrada/Sortida, basats en processadors auxiliars especialitzats.
Type B Code Learning outcomes
 B3 Configura un sistema de commutadors
És capaç de resoldre problemes de forma enginyosa, amb iniciativa i creativitat, tenint en compte els conceptes de l'assignatura.

 B8 Participa i col·labora activament en les tasques de l'equip, porta a terme la seva aportació individual en el temps previst, té en compte l'aportació dels altres i retroalimenta de forma constructiva.
Type C Code Learning outcomes

Continguts
Topic Sub-topic
1 Introducció 1.1 Visió general del sistema NDS
2 Organització interna d'un sistema programable 2.1 Components del computador
2.2 Regulació de l'accés al bus (Chip Select)
2.3 Controlador d'adreces de memòria
2.4 Zones de memoria reflectides
2.5 Accés als registres d'entrada/sortida
3 Organització interna de la plataforma NDS 3.1 Interconnexió dels components principals
3.2 Mapes de memòria i de registres d'entrada/sortida
3.3 Exemple de controlador d'entrada/sortida: botons
4 Controladors de les pantalles NDS 4.0 Introducció als gràfics per computador (2D)
4.1 Interconnexió dels components gràfics
4.2 Modes de fons gràfics
4.3 Bancs de Vídeo-RAM
4.4 Mode Frame Buffer
4.5 Registres de control dels fons
4.6 Fons de text
4.7 Fons de rotació/escalat
4.8 Objectes gràfics en moviment (sprites)
5 Sincronització d'Entrada/Sortida 5.1 Necessitat de la sincronització d'E/S
5.2 Sincronització per enquesta
5.3 Sincronització per interrupcions
5.4 El controlador d'interrupcions
5.5 Gestió de les Rutines de Servei d'Interrupció (RSI)
5.6 Sincronització per interrupcions de temps
6 Processos de transferència d'Entrada/Sortida 6.1 Transferència mitjançant CPU
6.2 Transferència mitjançant DMA (Direct Memory Access)
6.3 El controlador de DMA
6.4 Exemples de transferència per DMA
7 Controlador de so de la NDS 7.1 Característiques bàsiques
7.2 Reproducció de so mostrejat
7.3 So polifònic i variació de freqüència
7.4 Accés al hardware del controlador de so
8 Comunicació entre els processadors ARM9 i ARM7 8.1 Necessitats de comunicació entre processadors
8.2 Sincronització mitjançant IPCSYNC
8.3 Exemple de sincronització
8.4 Transferència d'informació mitjançant IPCFIFO
8.5 Exemple de transferència

Planificació
Methodologies  ::  Tests
  Competences (*) Class hours
Hours outside the classroom
(**) Total hours
Activitats Introductòries
1 0 1
Sessió Magistral
A7
CM9
16 16 32
Resolució de problemes, exercicis a l'aula ordinària
A7
CM9
10 22 32
Pràctiques a laboratoris
A7
CM9
24 24 48
Atenció personalitzada
4 0 4
 
Proves de desenvolupament
A7
CM9
2 16 18
Proves pràctiques
A7
CM9
B3
B8
2 0 2
Proves objectives de tipus test
A7
CM9
1 12 13
 
(*) On e-learning, hours of virtual attendance of the teacher.
(**) The information in the planning table is for guidance only and does not take into account the heterogeneity of the students.

Metodologies
Methodologies
  Description
Activitats Introductòries Presentació de l'assignatura
Sessió Magistral Explicació teòrica dels continguts de l'assignatura. Sempre que es pugui s'utilitzarà material propi (documents PDF) que es projectarà amb el canó de vídeo
Resolució de problemes, exercicis a l'aula ordinària Problemes que es resoldran a classe (amb participació dels alumnes) per tal de reforçar els coneixements teòrics
Pràctiques a laboratoris Desenvolupament d'un programa sobre la plataforma NDS, amb rutines escrites en llenguatge màquina del processador ARM i parts escrites en llenguatge C. El programa consistirà en un joc matricial
Atenció personalitzada Hores de consulta per esclarir dubtes sobre teoria, problemes o la pràctica

Atenció personalitzada
Description

Temps reservat per resoldre dubtes dels alumnes de manera individual. A causa de l’actual emergència sanitària, l’atenció a l’estudiant només es realitzarà mitjançant reunions en línia, en horaris concertats prèviament per correu electrònic o qualsevol altra eina virtual.

Horari oficial de consulta: http://deim.urv.cat/personal/llistat/15.html


Avaluació
Methodologies Competences Description Weight        
Proves pràctiques
A7
CM9
B3
B8
Es realitzarà un programa utilitzant C i llenguatge màquina de l'ARM, per tal d'implementar un joc sobre la plataforma NDS. El programa es desenvoluparà en dues fases. Els alumnes formaran grups de fins a 4 components, cadascun dels quals s'encarregarà de programar unes tasques concretes en cada fase, així com un programa de test específic per a provar el funcionament de les tasques implementades (obligatori). Al final de cada fase es realitzarà una entrevista personalitzada a cada membre del grup. Les notes seran independents de la resta del grup, i es podran limitar en funció del número de tasques integrades al programa final. La nota de pràctiques de l'assignatura serà la mitjana aritmètica de les dues notes obtingudes a les entrevistes. S'exigirà una nota mínima de 4 (sobre 10) en cada una de les fases per tenir dret a fer mitjana amb la resta de notes de l'assignatura. 30
Proves de desenvolupament
A7
CM9
Examen de 2 hores on caldrà resoldre un problema concret, que consistirà en implementar un programa sobre la plataforma NDS per realitzar tasques que requeriran Entrada/Sortida d'informació, tot utilitzant C i llenguatge màquina de l'ARM. A la solució presentada, l'alumne haurà de demostrar que domina les tècniques bàsiques de la programació de l'Entrada/Sortida d'informació (accés a registres d'E/S, sincronització per enquesta/interrupció, etc.). 40
Proves objectives de tipus test
A7
CM9
Examen tipus test sobre el Moodle amb unes 15 preguntes sobre tots els conceptes explicats a classe de teoria. Les preguntes poden ser de resposta única sobre 4 opcions, on les opcions incorrectes resten 1/3 del valor de l'opció correcta, o bé de resposta calculada, on les respostes incorrectes no resten. 30
Others  
 
Other comments and second exam session

S'exigirà una nota mínima de 4 sobre 10 en cada un dels apartats d'avaluació de l'assignatura (cada fase de la pràctica, problema i test), per tal de tenir dret a aprovar l'assignatura, tant en primera com en segona convocatòria.

L'assignatura s'aprova si la mitjana ponderada de les proves, arrodonida a la unitat, és superior o igual a 5 sobre 10.

L'avaluació en segona convocatòria té la mateixa estructura que en primera convocatòria, és a dir, pràctiques (dues fases), problema i test, però només serà necessari presentar-se de les parts en les que en primera convocatòria no s'hagi superat la nota mínima (4 sobre 10). També es permetrà presentar-se a pujar nota de les parts superades, però caldrà tenir en compte que la nota definitiva serà la de l'última solució presentada, fins i tot en el cas que s'obtingués un resultat pitjor que en primera convocatòria.

Durant la realització de totes les proves no es permetrà la utilització de cap mena de dispositiu electrònic, ni tampoc es permetrà consultar cap tipus de documentació.

Durant la realització de l'examen es fixarà un temps límit que s'haurà de respectar estrictament. Es rebutjaran totes les solucions presentades un segon després del temps límit, la qual cosa suposarà una nota de No Presentat en aquella convocatòria.

Els exàmens de test i del problema es realitzaran de forma presencial. A causa de l'emergència sanitària, les entrevistes de practiques es realizaran mitjançant videoconferència individual.


Fonts d'informació

Bàsica William Holh, ARM Assembly Language: Fundamentals and Techniques, CRC Press, 2009

Les principals fonts d'informació son els materials docents desenvolupats pels propis professors de l'assignatura, disponibles al Moodle.

Complementària

Recomanacions

Subjects that continue the syllabus
ESTRUCTURA DE COMPUTADORS/17234108
ESTRUCTURA DE SISTEMES OPERATIUS/17234113

Subjects that are recommended to be taken simultaneously
PROGRAMACIÓ/17234114

Subjects that it is recommended to have taken before
FONAMENTS DE COMPUTADORS/17234002
FONAMENTS DE PROGRAMACIÓ I/17234001
FONAMENTS DE PROGRAMACIÓ II/17234131
(*)The teaching guide is the document in which the URV publishes the information about all its courses. It is a public document and cannot be modified. Only in exceptional cases can it be revised by the competent agent or duly revised so that it is in line with current legislation.