LU-MOP-b20
Ī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:
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. |
|
08.10.2020. |
Komandu pieraksts, aritmētiskās un bitu operācijas. (video) Programmu izstrādes vide un darba plūsma. (Slaidi) |
|
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) |
|
29.10.2020. |
Apakšprogrammu izsaukumi, saskarne ar "C". (video)
|
|
05.11.2020. |
Simboliskie dati, kodu tabulas. (video) |
|
12.11.2020. |
Lielais kontroldarbs KD1.
|
|
19.11.2020. |
Izteiksmes un makro valoda. (video) |
|
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.
|
|
10.12.2020. |
Sistēmas uz čipa (SoC)
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
|
|
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
- Pieslēgties kursa serverim.
- Savā mājas direktorijā izveidot direktoriju
md0
- 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.
Pirmā kontroldarba rezultātu uzlabošanas iespēja
KD1 bija divi programmēšanas uzdevumi (3. un 4.). Jums iespēja uzlabot savu rezultātu par šiem uzdevumiem iesniedzot tos elektroniski, līdzīgi kā MD1.
3. uzdevums
Uzrakstīt no “C” izsaucamu ARM asemblera funkciju,
int kd1u3(char *T);
kas tai padotā simbolu virknē T (patvaļīga garuma, noslēgta ar 0x00 baitu) aizvieto lielos burtus ar mazajiem un mazos ar lielajiem.
Piemēram: kd1u3("AsTalaVISTA")
izmainīs simbolu virkni uz "aStALAvista"
Pārējos simbolus jāatstāj neskartus. Funkcija vienmēr atgriež 0.
Funkcija testējama izsaucot to no C valodā rakstītas funkcijas main().
Parametri uzdevuma testēšanai, tātad main() funkcijai, simbolu virkne bez tukšumiem un pēdiņām:
- apstrādājamā virkne (bez tukšumiem)
Programmai main() jāizdrukā apstrādātā simbolu virkne (un nekas cits).
Piemēram, programmas izsaukums ar šādām virknēm dod sekojošu rezultātu
$> kd1u3 AsTalaVISTA aStALAvista
Asemblera funkcijas nosaukums un specifikācija tieši tā, kā augstāk minēts.
Risinājumu failus kd1u3.s, kd1u3.h un kd1u3_main.c iesniegt direktorijā
~/kd1u3
4. uzdevums
Uzrakstīt no “C” izsaucamu ARM asemblera funkciju
int kd1u4(unsigned int N);
kura, lietojot C bibliotēkas funkcijas printf()
izsaukumu
ar formāta virkni "%x\n"
(formāts norāda heksadecimāla skaitļa izvadu),
drukā visus "īpašos" naturālos skaitļus no 1 līdz N (ieskaitot).
Par "īpašiem" sauc tos skaitļus, kuru heksadecimālajā pierakstā ciparusumma pāra pozīcijās ir vienāda ar ciparu summu nepāra pozīcijās.
Piemēram, skaitlis "109A"
ir īpašs.
Funkcija testējama izsaucot to no C valodā rakstītas funkcijas main().
Parametri uzdevuma testēšanai - main() funkcijai ir decimāls skaitlis N (kā simbolu virkne). Programmai jāizdrukā visi atrastie skaitļi līdz N, katrs savā rindā, un nekas cits. Tos drukā jūsu asemblera programma, izmantojot printf() saskaņā ar uzdevuma nosacījumiem. Pati main() funkcija neko neizdrukā, bet atgriež 0.
Funkcija kd1u4 vienmēr atgriež 0.
Asemblera funkcijas nosaukums un specifikācija tieši tā, kā augstāk minēts.
Risinājumu failus kd1u4.s, kd1u4.h un kd1u4_main.c iesniegt direktorijā
~/kd1u4
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.
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
- Intel XScale R Core Developer’s Manual, ON: 273473-002, Intel Corporation, 2004
Pamācības
- Kā uzstādīt arm-linux-gnueabi-gcc un qemu-arm Ubuntu un Debian vidēs.
- Kā lietot atkļūmotāju gdb ar qemu emulātoru.
Saites
- Noderīgas Linux komandas
- Easy 6502 assembly tutorial
- The ARM Architecture - slaidi no Arm.
- ARM Architecture - Wikipedija
- Introduction to ARM at DaveSpace
- Linaro - Open source software for ARM SoCs.
- Goldbolt.org - Compiler explorer
Dažādi
- Pentium FOOF bug: main = 0xc8c70ff0;
Atziņas
- Teach yourself programming in 10 years by Peter Norvig