AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Parität in Assembler

Ein Thema von Woyzeck · begonnen am 6. Nov 2010 · letzter Beitrag vom 7. Nov 2010
Antwort Antwort
Woyzeck

Registriert seit: 9. Jun 2009
60 Beiträge
 
#1

Parität in Assembler

  Alt 6. Nov 2010, 18:54
Hallo zusammen,

ich bin absoluter Frischling in Assembler. Meine Aufgabe ist es eine 4-Bit-Zahl um den dazugehörigen Paritätsbit zu erweitern.

Wie ich ihn anhängen kann, denke ich zu wissen:

shll $1, %eax
or p,%eax , wobei in p entweder eine 0 oder eine 1 drinsteht.

Bei der Berechnung des Paritätsbits hapert es aber doch gewaltig, da ich weder Sprung-, noch Konditionalbefehle benutzen darf.

Könnt ihr mir weiterhelfen?

Mit freundlichen Grüßen

Woyzeck
  Mit Zitat antworten Zitat
Benutzerbild von implementation
implementation

Registriert seit: 5. Mai 2008
940 Beiträge
 
FreePascal / Lazarus
 
#2

AW: Parität in Assembler

  Alt 6. Nov 2010, 19:09
Also die Berechnung sollte doch eigentlich kein Problem sein

1234 mod 2 = 0 => gerade
2345 mod 2 = 1 => ungerade

... und da hast du schon deine 0/1.
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#3

AW: Parität in Assembler

  Alt 6. Nov 2010, 19:11
meine letzten Assemblerroutinen habe ich vor 16 Jahren geschrieben, aber nach dem SHL müsste IMHO in das erste BIT der Inhalt des 2. Bit eingetragen werden.
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
Woyzeck

Registriert seit: 9. Jun 2009
60 Beiträge
 
#4

AW: Parität in Assembler

  Alt 6. Nov 2010, 19:52
Also die Berechnung sollte doch eigentlich kein Problem sein

1234 mod 2 = 0 => gerade
2345 mod 2 = 1 => ungerade

... und da hast du schon deine 0/1.
Das ist nicht der Paritätsbit. Ein Paritätsbit gibt nicht an, ob eine Zahl gerade oder ungerade ist, sondern ob die Anzahl der Einsen in binärer Darstellung gerade oder ungerade ist... Aus einer 2 = 0b0010 soll also 0b00101 = 5 werden.


meine letzten Assemblerroutinen habe ich vor 16 Jahren geschrieben, aber nach dem SHL müsste IMHO in das erste BIT der Inhalt des 2. Bit eingetragen werden.
Auch das würde als Parität einfach nur angeben, ob Zahl gerade oder ungerade, was aber nicht die Definition der Parität ist.


Ich hab mittlerweile eine Lösung entwickelt, die nicht sonderlich elegant, aber funktionsfähig ist.

Code:

movl $15,%eax # wertübergabe
movl %eax,%edx # mit edx rechne ich
movl $0,%ecx # ecx speichert die anzahl der 1er

and $1,%edx # edx= letzte Stelle von eax
addl %edx,%ecx # summieren der quersumme

movl %eax,%edx

shrl %edx
and $1,%edx
addl %edx,%ecx

movl %eax,%edx

shrl $2,%edx
and $1,%edx
addl %edx,%ecx

movl %eax,%edx

shrl $3,%edx
and $1,%edx
addl %edx,%ecx

and $1,%ecx

shll %eax
or %ecx,%eax
Ich teste das jetzt nochmal schnell durch, aber eigentlich sollte das tun.

Geändert von mkinzler ( 6. Nov 2010 um 19:55 Uhr) Grund: Code-Tag eingefügt
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 15. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#5

AW: Parität in Assembler

  Alt 7. Nov 2010, 02:13
Bei der Berechnung des Paritätsbits hapert es aber doch gewaltig, da ich weder Sprung-, noch Konditionalbefehle benutzen darf
Dein Lehrer möchte Dich ärgern?
Dann würde ich ihm eine Lösung präsentieren, die er vielleicht nicht erwartet hat.
Man nehme vorberechnete 16 Bytes in denen der Wert der Parität steht.
Code:
Zahl |  Parität
0000 => 0
0001 => 1
0010 => 1
0011 => 0
...
1111 => 0
In Assembler wird das mit Define Byte abgelegt:
Code:
.data
LU_TABLE:
DB 0,1,1,0,....,0

.text
LEA %ebx, LU_TABLE
# jetzt die Zahl in Register %eax dazuaddieren und man hat die Adresse
# an der die Parität steht
ADD %ebx, %eax
# Inhalt des Bytes auslesen
MOVB %cx, [%ebx]
Also ich stehe ja mit X86-Assembler auf Kriegsfuss, daher sind bestimmt noch Fehler in obigem Code.
Aber das Prinzip der Nachschlagetabelle sollte klar geworden sein.
  Mit Zitat antworten Zitat
schöni

Registriert seit: 23. Jan 2005
Ort: Dresden
445 Beiträge
 
Delphi 7 Personal
 
#6

AW: Parität in Assembler

  Alt 7. Nov 2010, 02:34
Wenn ich mich richtig erinnere, gibt es ein Parity Flag im Flagregister. Müsste daher ausreichen, dieses Flag abzufragen. Es sollte auch Assemblerbefehhle geben, die das Flagregister laden können. Auf jeden Fall PUSHF, welcher das Flagregister auf den Stack schreibt. Von da aus in ein CPU Register POPen sollte kein Problem sein. Dann das Flag per Bitmaske auswerten.

Bei Sprungbefehlen in Abhängigkeit vom Parity Flag bin ich mit nicht sicher. Aber auf den Stack pushen und in ein Register poppen, um dann das Parity Flag abzufragen sollte klappen.
Damit der Topf nicht explodiert, lässt man es ab und zu mal zischen.
  Mit Zitat antworten Zitat
Benutzerbild von BUG
BUG

Registriert seit: 4. Dez 2003
Ort: Cottbus
2.094 Beiträge
 
#7

AW: Parität in Assembler

  Alt 7. Nov 2010, 11:12
Code:
JNP [Ziel] -> Sprung wenn Parity-Flag Null
JP [Ziel] -> Sprung wenn Parity-Flag Eins
Aber darf er ja nicht benutzen

EDIT:
Die engl. Wikipedia rückt ein paar interessante Informationen raus.
Intellekt ist das Verstehen von Wissen. Verstehen ist der wahre Pfad zu Einsicht. Einsicht ist der Schlüssel zu allem.

Geändert von BUG ( 7. Nov 2010 um 11:15 Uhr)
  Mit Zitat antworten Zitat
Amateurprofi

Registriert seit: 17. Nov 2005
Ort: Hamburg
1.041 Beiträge
 
Delphi XE2 Professional
 
#8

AW: Parität in Assembler

  Alt 7. Nov 2010, 16:55
Wie wär es hiermit ?

Delphi-Quellcode:
FUNCTION AddParity(value:byte):byte;
asm
      test al,al // Setzt u.a. das Parity-Flag
      lahf // Flags in AH (Bit 2 = Parity Flag)
      shr ah,2 // Parity-Flag in Carry-Flag schieben
      rcl al,1 // AL um 1 Bit nach oben und Carry-Flag in Bit 0
end;
Achtung :
Das Parity-Flag ist dann = 1, wenn die Anzahl der 1er-Bits gerade ist.

Wenn 32-Bit Werte benutzt werden sollen, wird es etwas länger
Delphi-Quellcode:
FUNCTION AddParity(value:integer):integer;
asm
      mov edx,eax
      test eax,eax
      lahf
      shr ah,2
      rcl edx,1
      mov eax,edx
end;
Gruß, Klaus
Die Titanic wurde von Profis gebaut,
die Arche Noah von einem Amateur.
... Und dieser Beitrag vom Amateurprofi....
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:11 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz