Difference between revisions of "LU-MOP-b14"

From DiLab
Jump to: navigation, search
(26.05.2014.)
m (3. uzdevums)
Line 223: Line 223:
Piemēram, programmas izsaukums ar šādām virknēm dod sekojošu rezultātu
Piemēram, programmas izsaukums ar šādām virknēm dod sekojošu rezultātu
$> kd1u3 Pirmais-kontroldarbs janis berzins
$> kd1u3 Pirmais-kontroldarbs janis berzins
P01m000-kont1old0110
P01m000-ko0t1old0110


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

Revision as of 15:23, 13 May 2014

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)

Kursa mērķis

Kursa mērķis ir iepazīstināt ar zema līmeņa programmēšanu Asemblerā, ņemot ARM platformu kā konkrētu izstrādes mērķi. 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, 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 nopiens kurss ar būtisku slodzi. Piemēram, varat iepazīties ar to, ko iepriekšējie studenti rakstīja pēc šī kursa: MOP-m kursa atsauksmes 2013. Veiksmi šajā gadā.

Vērtējums

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

  • Dalība klasē, jautājumi, atbildes, diskusijas
  • MK (1,2,3) = (6+6+13%)
  • MD (1,2) = (15+20%)
  • KD1 (20%)
  • Eksāmens (20%)

Kalendārs

Datums, nedēļa Kursa saturs Uzdevumi

03.02.2014.

Ievads kursā. Kursa mērķi. Iegultās un mazo procesoru sistēmas. ARM arhitektūra. Mācību izstrādes vide.

10.02.2014.

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

17.02.2014.

Skaitļu attēlošana papildkodā.

MK1 kontroldarbs

24.02.2014.

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

03.03.2014.

Programmu izstrādes vide.

"asm1" serveris praktiskajiem darbiem.

MK2 kontroldarbs

10.03.2014.

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

17.03.2014.

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

Pasludināts MD1.

24.03.2014.

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

MK3 kontroldarbs

31.03.2014.

Apakašprogrammu izsaukumi, saskarne ar "C".

07.04.2014.

Simboliskie dati, kodu tabulas.

MD1 termiņš.

Uzdots MD2.

14.04.2014. - 21.04.2014.

Lieldienu brīvdienas

28.04.2014.

Izteiksmes un makro valoda.

Iekļautais asemblers.

Pasludināts kursa projekts KP.

05.05.2014.

Brīvdiena, jo 4. maijs svetdienā.

Lielais kontroldarbs KD1 (Tiešsaistē, pieejams no eStudijām, 6.05.2014. no 8:30 līdz 21:00)

12.05.2014.

Programmatūras izstrādē lietoto rīku darbības principi.

MD2 termiņš

19.05.2014.

Instrukciju izpildes laiki.

Sistēmas sāknēšana, priviliģētās operācijas.

Termiņš eksāmena formas izvēlei KD/KP.

26.05.2014.

Kursa vielas pārskats.

KD1 noskaņto programmēšanas uzdevumu iesniegšanas termiņš

xx.06.2014.

xx:xx Eksāmens

 

Kontroldarbi

MK1

Skaitļu formāti un pārvedioš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.


MD1

Aritmētiskās progresijas summa (apraksts).

MD2

Matricu reizināšana (apraksts).

KP

Kursa projekts.

Grafiskā bibliotēka.


KD1

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 replace(char *str, char *alpha, char *beta);

kas tai padotā patvaļīga garuma, ar 0x00 baitu noslēgtā virknē meklē burtus no "alpha" un "beta" virknēm. "alpha" un "beta arī ir noslēgti ar 0x00 baitu.

Virknes burtus funkcijai jāaizstāj sekojoši:

  • tos, kas sastopami virknē "alpha", funkcijai jāaizstāj ar simbolu '0' (ASCII kods 48);
  • tos, kas sastopami virknē "beta" bet ne virknē "alpha", jāaizstāj ar simbolu '1';
  • pārējos simbolus jāatstāj neskartus.


Funkcija testējama izsaucot to no C valodā rakstītas funkcijas main().

Parametri uzdevuma testēšanai, tātad main() funkcijai, ir trīs simbolu virknes bez tukšumiem un pēdiņām:

  • apstrādājamā virkne (bez tukšumiem)
  • vārds
  • uzvārds

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 Pirmais-kontroldarbs janis berzins
P01m000-ko0t1old0110

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 list_special(unsigned int N);

kas (lietojot printf izsaukumu ar formāta virkni "%x\n") drukā visus "īpašos" naturālos skaitļus no 1 līdz N (sešciparu decimāls skaitlis), ieskaitot.

Par "īpašiem" sauc tos skaitļus, kuru heksadecimālajā pierakstā ciparu summa pāra pozīcijās ir vienāda ar ciparu summu nepāra pozīcijās. Piemēram, skaitlis "109A" ir īpašs, jo 1+9 == 0+A.


Funkcija testējama izsaucot to no C valodā rakstītas funkcijas main().

Parametri uzdevuma testēšanai - main() funkcijai ir skaitlis N (kā simbolu virkne). Programmai jāizdrukā 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.

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

Literatūra

Grāmatas un citi resursi

  • ARM Architecture Reference Manual, ARM DDI 0100I, ARM Limited, 2005.
  • Intel R XScaleTM Microarchitecture Assembly Language Quick Reference Card ARM Instruction Set, Intel Corporation, 2001
  • Intel XScale R Core Developer’s Manual, ON: 273473-002, Intel Corporation, 2004
  • Intel R IXP42X Product Line of Network Processors and IXC1100 Control Plane Processor Developer’s Manual, ON: 252480-006US, Intel Corporation, 2006
  • 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.

Atziņas