LU-MOP-b

From DiLab
Revision as of 12:52, 19 September 2023 by Leo (talk | contribs) (MD0)
Jump to: navigation, search

Īsceļi: Kalendārs | Pārbaudījumi | MD | Projekts | Literatūra | Pamācības | Šodiena (ja ir lekcija)

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

05.09.2023.

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).

12.09.2023.

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.

Lab: Skaitļu pārveidošana starp skaitīšanas sistēmām ar dažādām bāzēm.

19.09.2023.

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


Lab: Q1 risinājums. Negatīvi skaitļi aparatūrā.

  • HW0 termiņš
  • Mazais kontroldarbs Q1

26.09.2023.

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.

Lab: Q2 risinājums

  • Mazais kontroldarbs Q2
  • Pasludināts HW1.

03.10.2023.

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

Lab: Makefile uzbūve un veidošana

10.10.2023.

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

Lab. Asemblera programmas trasēšana, sekošana reģistru vērtībām.

17.10.2023.

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

MK3 pārskats

Gatavošanās MK3

24.10.2023.

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

Lab: Atkļūdotāja lietošana

  • Mazais kontroldarbs Q3
  • Termiņš HW1 23:59

31.10.2023.

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

07.11.2023.

Simboliskie dati, kodu tabulas. (video)

14.11.2023.

Lielais kontroldarbs KD1.


  • Pasludināts kursa projekts KP.

21.11.2023.

Izteiksmes un makro valoda. (video)

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

28.11.2023.

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

  • Termiņš eksāmena formas izvēlei KD/KP (23:59)

05.12.2023.

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.

12.12.2023.

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.

Case study:

Kursa vielas pārskats

19.12.2023.

xx:xx Eksāmens - Kontroldarbs KD2

xx:xx Eksāmens - termiņš kursa projektam


Termiņš visiem iesniedzamajiem darbiem 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.
  • Kompilējot programmas jālieto XScale arhitektūra, gluži kā laboratorijas 1. darba Makefile piemērā. Nenorādot arhitektūru var rasties programmas kļūdas par ko gcc neinformē, piemēram, mov ar konstanti kas garāka par 8 bitiem.


Q1

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

Q2

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

Q3

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

MD

HW0

  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).

KP

Kursa projekts.

Grafiskā bibliotēka.

Literatūra

Makefile

GDB

Asemblers

ARM

Xscale


Grāmatas un citi resursi

  • 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