Difference between revisions of "LU-MOP-b20"

From DiLab
Jump to: navigation, search
(Created page with "<big> '''Īsceļi:''' Kalendārs | Pārbaudījumi | MD | KD | Projekts | #Literatūra | Literatūr...")
 
(KD1)
Line 301: Line 301:
  
 
Isumā, KD1 paredzami jautājumi un jūsu atbildes, kā arī programmēšanas daļa 1-2 nelieliem uzdevumiem.
 
Isumā, KD1 paredzami jautājumi un jūsu atbildes, kā arī programmēšanas daļa 1-2 nelieliem uzdevumiem.
<!--
+
 
 
'''Sīkāki komentāri:'''
 
'''Sīkāki komentāri:'''
  
 +
<!--
 +
-->
 
Kontroldarba tēmas ir visas lekcijas līdz kontroldarba datumam.
 
Kontroldarba tēmas ir visas lekcijas līdz kontroldarba datumam.
  
Line 322: Line 324:
  
 
Kontroldarba izpildei paredzētas 90 minūtes, tā pat kā lekcijas garums LU DF (2x45min).
 
Kontroldarba izpildei paredzētas 90 minūtes, tā pat kā lekcijas garums LU DF (2x45min).
 +
<!--
 
-->
 
-->
  
 
<!--
 
<!--
-->
 
  
 
===Pirmā kontroldarba rezultātu uzlabošanas iespēja===
 
===Pirmā kontroldarba rezultātu uzlabošanas iespēja===

Revision as of 10:07, 14 September 2021

Īsceļi: Kalendārs | Pārbaudījumi | MD | KD | Projekts | Literatūra | Pamācības

Mašīnorientētā programmēšana (MOP)

LU DF bakalaura studiju kurss DatZ4017, meklēt eStudijās.


  • Pasniedzējs: Leo Seļāvo (epasts: vards.uzvards @ gmail.com)
  • Komunikācija ar pasniedzēju iespējama gan kursa forumā, gan pa epastu, vai arī iepriekš sarunājot, klātienē.


Kursa mērķis

Kursa mērķis ir iepazīstināt ar zema līmeņa programmēšanu Asemblerā, lietojot ARM platformu kā konkrētu izstrādes mērķa vidi. Asemblera instrukcijas ir aparatūrai tuvākās procesora izpildes komandas, līdz ar to kursā tiek stāstīts arī par to, kā darbojas procesors un cita aparatūra, kādi ir tā resursi, un kā to ietekmēt ar Asemblera programmām. Tiek apskatīts arī kā veidot saskarni starp Asembleru un augstāka līmeņa programmām, tai skaitā C.

Šis ir nopietns kurss ar būtisku slodzi. Piemēram, varat iepazīties ar to, kā iepriekšējo gadu studenti vērtējuši šo kursu: MOP-m kursa atsauksmes. Veiksmi šajā gadā.

Vērtējums

Gala vērtējums kursā veidosies no sekojošiem faktoriem:

  • Dalība kursā: jautājumi, atbildes, un diskusijas, tai skaitā kursa komunikācijas vietnē.
  • 15% - mazie kontroldarbi (MK: 1+3+3+8)
  • 35% - mājas darbi (MD: 15+20)
  • 25% - semestra vidus kontroldarbs (KD1)
  • 25% - eksāmens (EX). Eksāmena forma: kursa projekts vai rakstisks.


Lai saņemtu sekmīgu vērtējumu kursā, jāsavāc vismaz 40% kopā par visiem kursa darbiem, un jānoliek eksāmens ar vērtējumu vismaz 40%. Tātad, ar eksāmenu vien nepietiek, jāpilda arī citi darbi.

Akadēmiskā goda sistēma

Akadēmiskā goda sistēma - noteikumi, kuriem jums kā studentiem jāpiekrīt lai varētu sekmīgi piedalīties šajā kursā.

Kalendārs

Datums, nedēļa Kursa saturs Uzdevumi

09.09.2020.

Ievads kursā (lekcija). Kursa prasības un uzdevumi. (Slaidi)

Uzstādiet Ubuntu vai citu Debian saimes Linux darba vidi uz sava datora, kurā strādāsiet pie kursa uzdevumiem. Kursā mēs izmantosim ARM kros-kompilācijas rīkus. Ubuntu operētājsistēmu Jūs varat darbināt kādā no sekojošiem veidiem:

  • tiešā veidā (native installation);
  • "Dual boot" režīmā, blakus jūsu ikdienas operētājsistēmai;
  • kā virtuālu mašīnu zem jūsu iecienītās operētājsistēmas (MS Windows vai MacOS).

Uzstādiet arī uz sava datora Zoom Meetings klientu, lai varam ērti komunicēt lekcijās, praktiskajos darbos un konsultācijās.

16.09.2020.

Sešpadsmitnieku un citas skaitīšatas sistēmas datoriem. (Slaidi) Pārveidojumi starp dažādām sistēmām, aritmētiskās darbības. Biti, baiti, vārdi, nibbles.

23.09.2020.

Skaitļu attēlošana papildkodā. (Slaidi)

Mācību izstrādes vide. (Slaidi)

01.10.2020.

Iegultās un mazo procesoru sistēmas. ARM arhitektūra. Mācību izstrādes vide. (Slaidi)

Procesora uzbūve. Operatīvā atmiņa. Procesora un atmiņas sadarbība. Adreses. Reģistri. Procesora režīmi.

  • Mazais kontroldarbs MK2
  • Pasludināts MD1.

08.10.2020.

Komandu pieraksts, aritmētiskās un bitu operācijas. (video)

Programmu izstrādes vide un darba plūsma. (Slaidi)

  • Atkārtota MK1 rakstīšanas iespēja (lekcijas otrajā pusē).
  • Pasludināts MD2.

15.10.2020.

Vadības maiņas komandas, testi, bitu operācijas. (video)

22.10.2020.

Adresācijas režīmi, darbs ar atmiņu. (video)

  • Termiņš MD1 23:59
  • Mazais kontroldarbs MK3

29.10.2020.

Apakšprogrammu izsaukumi, saskarne ar "C". (video)


05.11.2020.

Simboliskie dati, kodu tabulas. (video)

12.11.2020.

Lielais kontroldarbs KD1.

  • Kontroldarbs KD1 būs pieejams tiešsaistē, e-studijās, zemāk sadaļā "Pārbaudījumi".
  • Kontroldarbu uzsākot jums būs dotas 90 minūtes laika. Kontroldarbu varēs veikt tikai vienu reizi. Tāpēc nodrošiniet sevi ar laiku un vietu kur jūs neviens netraucēs. Uzdevumi paredzami kā atbildes uz jautājumiem, gan arī kā programmēšanas uzdevumi.
  • Pasludināts kursa projekts KP.

19.11.2020.

Izteiksmes un makro valoda. (video)

  • Termiņš KD1 noskaņotiem KD1 programmēšanas uzdevumiem serverī: 23:59.

26.11.2020.

Iekļautais asemblers. Programmatūras izstrādē lietoto rīku darbības principi. Koda optimizācijas.

03.12.2020.

Instrukciju izpildes laiki.

  • Intel XScale R Core Developer’s Manual
    • A.2.1.2 — bilde ar procesora instrukciju izpildes “cauruli” un tuvumā esošie teksti, par to, kā pa to virzās instrukcijas;
    • 10.4 — cik ātri izpildās instrukcijas, piemēram, reizināšana;
    • 5 — kā strādā zarošanās paredzēšanas mehānisms;
    • 4 un 6 — cache atmiņa pastāv un noder, un ir atsevišķa gan instrukcijām, gan datiem;
    • A.3–A.5 — paanalizējam Intel-a ieteiktās optimizācijas.
  • Termiņš eksāmena formas izvēlei KD/KP (23:59)

10.12.2020.

Sistēmas uz čipa (SoC)

  • Dokumentācija (datasheet), tipiskas sadaļas.
  • Atmiņas izklājums (memory map)
  • Komunikācijas protokoli: RS232, USB, SPI, I2C, 1-wire, CAN.
  • Perifērijs iekārtas: Taimeri, GPIO, USART
  • Watchdog taimeris
  • Sistēmas sāknēšana, priviliģētās operācijas.

Kursa vielas pārskats.

17.12.2020.

Kursa kopsavilkums.

07.01.2020.

10:30 Eksāmens - Kontroldarbs KD2

10:30 Eksāmens - termiņš kursa projektam



  • Termiņš visiem iesniedzamajiem darbiem (10:30)
  • Termiņš kd2u9 noskaņotam uzdevumam uz servera - dienas beigas (23:59).


Pārbaudījumi

Tipiskas kļūdas pārbaudījumos:

  • Ja prasīts izvadīt tikai rezultātu, tad TIKAI rezultātu. Piemēram "17" nevis "summa=17".
  • Uzdevumu iesniedzamo direktoriju vārdi ir "case sensitive". Piemēram, ja prasība ir "md1", tad "MD1" tiks ignorēta.
  • Programmu izpilde jātestē uz kursa servera. Pat, ja programma iet uz jūsu datora bet neiet uz servera, tā netiks ieskaitīta.


MK1

Skaitļu formāti un pārveidošana: decimālā, heksadecimālā, oktālā, binārā.

MK2

Skaitļi ar zīmi, divnieka papildkodā, to pārveidošana.

MK3

Asemblera pirmkoda lasīšana un izpratne. Sekot neliela koda fragmentam un noteikt reģistru vērtības pēc tā izpildes.

MD

MD0

  1. Pieslēgties kursa serverim.
  2. Savā mājas direktorijā izveidot direktoriju md0
  3. Direktorijā md0 izveidot teksta failu out.txt kurā ierakstīts teksts "aRM" bez pēdiņām.

MD1

Aritmētiskās progresijas summa (apraksts).

MD2

Matricu reizināšana (apraksts).

KD

KD1

Isumā, KD1 paredzami jautājumi un jūsu atbildes, kā arī programmēšanas daļa 1-2 nelieliem uzdevumiem.

Sīkāki komentāri:

Kontroldarba tēmas ir visas lekcijas līdz kontroldarba datumam.

Kontroldarbā paredzami uzdevumi, kas balstīsies gan uz koda izpratni, gan arī programmu rakstīšana asemblerā.

Piemērs kontroldarbam varētu būt sekojošs:

  1. Dots pirmkoda listings ar datu definīcijām. Uzrakstīt, kādās adresēs kādi dati atradīsies. Jāsaprot gan direktīvas pirmkoda izlīdzināšanai, gan datu tipi, tai skaitā simboliskie, piemēram, ascii un asciz, short, word, un tamlīdzīgi.
  2. Dots pirmkods asemblerā (apmēram 8-15 rindiņas) un dažu reģistru saturs. Izsekot programmai un uzrakstīt kāds būs reģistru saturs pēc programmas izpildes. Jums jāatpazīst līdz šim apskatītās instrukcijas, tai skaitā MOV varianti, aritmētiskās, vadības kontroles (piem. BX), steka operāciju instrukcijas (piem. LDMFD), un parējās par ko runāts slaidos un video materiālā. Katram studentam uzdevums atšķirsies.
  3. Uzrakstīt no C izsaucamu asemblera funkciju, kas apstrādā tai padotos datus īpašā veidā.
  4. Uzrakstīt specifisku funkcijas kodu asemblerā kas lietojot "printf" izsaukumu (saskarne ar C, kā lekcijās) izvada tās rezultātu.

Komentāri par 3. un 4.: Kontroldarba laikā netiek sagaidīts, ka jūs pilnībā uzrakstīsiet šo kodu. Tā vietā tiek sagaidīts, ka jūsu rakstītais kods parādīs, ka jums ir skaidrs plāns kā rakstīt šādas programmas, un kā rakstīt saturīgu kodu asemblerā. Savukārt, pēc kontroldarba tiks dots laiks (vismaz nedēļa) lai šīs programmas uzrakstītu līdz galam, un noskaņotu. Tad tās tiek iesniegtas un vērtētas tā pat kā mājas darbi. Termiņi jau ir kursa wiki kalendārī.

Asemblera iemaņas 3. un 4. uzdevumiem nepārsniegs kursā apskatītās tēmas. Cerams, ka mājas darbu pildīšanas laikā būsiet guvuši vērtīgu pieredzi. Bez tās gan būs pagrūti.

Kontroldarba laikā nav aizliegts lietot literatūru. Savukārt, datoru lietot nav atļauts. Šeit es paļaujos uz jūsu goda prātu, kā arī uz Akadēmiskā goda sistēmu.

Kontroldarba izpildei paredzētas 90 minūtes, tā pat kā lekcijas garums LU DF (2x45min).


KD2

Jautājumi un atbildes, kā arī programmēšanas daļa nelielam uzdevumam.

9. KD2 programmēšanas uzdevums un iesniegšana

Uzrakstīt no “C” izsaucamu ARM asemblera funkciju

int kd2u9(char *str)

kas saņem kā parametru pointeri uz simbolu(baitu) virkni kura ir noslēgta ar 0x00 baitu un rēķina savdabīgu kontrolsummu. Tā saskaita vieninieku bitus katrā nepāra baitā un nulles bitus katrā pāra baitā no virknes str, līdz pēdējam nulles baitam neieskaitot. Funkcijas atgriežamā vērtība ir saskaitīto vieninieku un nuļļu summa.

Piemēram, ja str sastāvētu no četriem baitiem plus noslēdzošā nulles baita, kur katrs nepāra baits ir visi vieninieki bet pāra baits ir 7 nulles ar vienu vieninieku, tad atgriežamais rezultāts būtu 30 (14 nulles un 16 vieninieki). Savukārt, ja tajā pašā četru baitu virknē visi būtu vieninieki, tad rezultāts būtu 16.


Parametri uzdevuma testēšanai - main() funkcijai ir viena simbolu virkne. Asemblera programmai jāpadod pointeris uz šo simbolu virkni. Programmai main() jāizdrukā rezultāts kā integer skaitlis.

Asemblera funkcijas nosaukums un specifikācija tieši tā, kā augstāk minēts.

Risinājumu failus kd2u9.s, kd2u9.h un kd2u9_main.c iesniegt direktorijā

~/kd2u9


KP

Kursa projekts.

Grafiskā bibliotēka.

Literatūra

Grāmatas un citi resursi

  • ARM Architecture Reference Manual, (PDF), ARM DDI 0100I, ARM Limited, 2005.
  • ARM DeveloperSuite Assembler Guide: (web), (pdf).
    • Šeit pieejami visu instrukciju apraksti: Chapter 4, ARM Instruction Reference.
  • Intel XScale Microarchitecture Assembly Language Quick Reference Card ARM Instruction Set, Intel Corporation, 2001
  • Intel IXP42X Product Line of Network Processors and IXC1100 Control Plane Processor Developer’s Manual, ON: 252480-006US, Intel Corporation, 2006
  • Intel XScale(R) Core Developer’s Manual
  • Patterson and Hennessy, Computer Organization and Design, 4th Edition (@Amazon)
  • "Building Embedded Linux Systems" O'Reilly Media, 2008, ISBN 0596529686


Pamācības

Saites

  • Linaro - Open source software for ARM SoCs.

Dažādi

Atziņas