Hypercell ein ] Hypercell aus ] Zeige Navigation ] Verstecke Navigation ]
c++.net  
   

Die mobilen Seiten von c++.net:
https://m.c-plusplus.net

  
C++ Forum :: Assembler ::  inline asm-Funktion nach C, Bittest & array - Probleme     Zeige alle Beiträge auf einer Seite Auf Beitrag antworten
Autor Nachricht
Rudi Ratlos
Unregistrierter




Beitrag Rudi Ratlos Unregistrierter 06:58:00 06.02.2017   Titel:   inline asm-Funktion nach C, Bittest & array - Probleme            Zitieren

Hallo zusammen,
im recht alten Quellcode eines Decompilers finden sich zahlreiche Inline-ASM-Funktionen. Irgendwo in diesen Untiefen steckt allerdings der Wurm, in seltenen Konstellationen wird der Stack zerschossen. Viele Funktionen konnte ich bisher umschreiben, folgende macht mir aber Schwierigkeiten, da ich mit Assembler keinerlei Erfahrung habe.
Ich bin mir nicht sicher, ob Überläufe (absichtlich) ausgenutzt werden, der Code funktioniert aber (wie geschrieben, meistens).
Darunter befindet sich die C-Version, kann mir einer sagen, wo der Fehler steckt? In einem kurzen Test liefern beide Versionen völlig unterschiedliche Ergebnisse.
C++:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
const int16_t neg_pow2[]=
{
    0,-1,-3,-7,-15,-31,-63,-127,-255,-511,-1023,-2047,-4095,-8191,-16383,-32767
};
 
const uint32_t neg_pow2_0=(uint32_t)neg_pow2;
 
inline int16_t Get(uint8_t k, uint32_t wv)
{
    _asm
    {
        xor ecx, ecx
        mov cl,k
        mov eax,[wv]
        shl eax,cl
        shr eax, 16
        dec cl
        bt eax,ecx
        jc end_macro
        signed_value:inc cl
        mov ebx,[neg_pow2_0]
        add ax,word ptr [ebx+ecx*2]
        end_macro:
    }
}
 
inline int16_t Get2(uint8_t k, uint32_t wv)
{
    int32_t ecx = k;        // mov cl,k
    int32_t eax = wv;
    eax<<=ecx;              // shl eax,cl
    eax>>=16;               // shr eax, 16
    --ecx;                  // dec cl
    if((eax>>ecx) & 1)      // bt eax,ecx (?)
    {
        ++ecx;              // signed_value:inc cl
                                // mov ebx,[neg_pow2_0]
        eax += neg_pow2[ecx*2]; // add ax,word ptr [ebx+ecx*2]
    }
    return eax;
}

Die Funktion heißt leider wirklich Get und befindet sich in einer Quellcodedatei. Was sie macht, ist auf einen schnellen Blick für mich nicht ersichtlich.
HansKlaus
Mitglied

Benutzerprofil
Anmeldungsdatum: 19.04.2016
Beiträge: 259
Beitrag HansKlaus Mitglied 12:06:14 06.02.2017   Titel:              Zitieren

also ich habs jetzt natürlich nicht durchprobiert, aber mit jc end_makro wird doch das programm abgebrochen, wenn das bit gesetzt ist, während die if-anweisung in diesem fall ausgeführt wird. oder sehe ich das falsch?
Rudi Ratlos
Unregistrierter




Beitrag Rudi Ratlos Unregistrierter 16:45:29 06.02.2017   Titel:              Zitieren

Hallo, du hast völlig recht, danke.
Ein weiterer Fehler war, dass die Offsets in Asm in Byte angegeben sind. Das ist zwar logisch, gedacht habe ich daran jedoch nicht.
C++:
1
2
3
4
5
6
7
8
add ax,word ptr [ebx+ecx*2]
// ->
if(!((eax>>ecx) & 1))  // bt eax,ecx
{
    ++ecx;                // signed_value:inc cl
                          // mov ebx,[neg_pow2_0]
    eax += neg_pow2[ecx]; // add ax,word ptr [ebx+ecx*2]
}
C++ Forum :: Assembler ::  inline asm-Funktion nach C, Bittest & array - Probleme   Auf Beitrag antworten

Zeige alle Beiträge auf einer Seite




Nächstes Thema anzeigen
Vorheriges Thema anzeigen
Sie können Beiträge in dieses Forum schreiben.
Sie können auf Beiträge in diesem Forum antworten.
Sie können Ihre Beiträge in diesem Forum nicht bearbeiten.
Sie können Ihre Beiträge in diesem Forum nicht löschen.
Sie können an Umfragen in diesem Forum nicht mitmachen.

Powered by phpBB © 2001, 2002 phpBB Group :: FI Theme

c++.net ist Teilnehmer des Partnerprogramms von Amazon Europe S.à.r.l. und Partner des Werbeprogramms, das zur Bereitstellung eines Mediums für Websites konzipiert wurde, mittels dessen durch die Platzierung von Werbeanzeigen und Links zu amazon.de Werbekostenerstattung verdient werden kann.

Die Vervielfältigung der auf den Seiten www.c-plusplus.de, www.c-plusplus.info und www.c-plusplus.net enthaltenen Informationen ohne eine schriftliche Genehmigung des Seitenbetreibers ist untersagt (vgl. §4 Urheberrechtsgesetz). Die Nutzung und Änderung der vorgestellten Strukturen und Verfahren in privaten und kommerziellen Softwareanwendungen ist ausdrücklich erlaubt, soweit keine Rechte Dritter verletzt werden. Der Seitenbetreiber übernimmt keine Gewähr für die Funktion einzelner Beiträge oder Programmfragmente, insbesondere übernimmt er keine Haftung für eventuelle aus dem Gebrauch entstehenden Folgeschäden.