Forum: Mikrocontroller und Digitale Elektronik Multiplikation von zwei 16Bit Werten


von tikki (Gast)


Lesenswert?

Hallo Leute,

ich multipliziere 2 16Bit Zahlen mit einem MSP430F2330.
Meine Zeile in C lautet:  erg=Zahl1*Zahl2;
Leider wird in erg(eine uint 32bit Variable) nur RESLO, also die unteren 
16 bit des Ergebnisses eingetragen ...

Wie bekomme ich die Ganzen 32bit des Ergebnisses, ohne RESLO und RESHI 
mit Bitshifting in eine 32bit Variable schieben zu müssen.

Gruß
tikki

von g457 (Gast)


Lesenswert?

erg = (uint32_t)Zahl1 *Zahl2;

von tikki (Gast)


Lesenswert?

Wow, danke für die schnelle Antwort!

Wenn ich das nun noch mit einer Division verbinden möchte:

erg=((uint32_t)Zahl1 *Zahl2)/Zahl3;

Wäre das so korrekt?
Wenn sicher ist, dass NACH DER DIVISION in erg eine Zahl steht, die noch 
in 16bit darstellbar ist, kann ich dann für erg auch nur 16bit 
verwenden?


Vielen Dank, nochmals für die Hilfe!
tikki

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.