Forum: Compiler & IDEs -Wstrict-overflow


von Bauform B. (bauformb)


Lesenswert?

Guten Morgen!

Alte Programme provozieren neuerdings Warnungen. Dies ist kein 
unlösbares Problem, mir ist klar, wieso, weshalb, warum. Nur rein aus 
Neugier: wie geht ihr mit sowas um?
1
mkeproms.c: In function 'main':
2
mkeproms.c:118:10: warning: assuming signed overflow does not occur
3
when simplifying division [-Wstrict-overflow]
4
  118 |          top = ((en + 1) * 8192) / 256;
Das Programm baut in 27C64 EPROMs eine Checksum pro Chip ein, also für 
jeweils 8192 Byte. Von der Startadresse braucht man nur das High Byte, 
also wird durch 256 geteilt. Das kann man doch garnicht anders 
formulieren?!1!11

Das muss für maximal 5 EPROMs funktionieren, aber im Original kann der 
gcc das nicht wissen. Es hilft allerdings auch nicht, wenn ich ihm das 
sage:
1
if (ecnt <= 5) {
2
   chklist = 0x01F0;
3
   for (en = 0; en < ecnt; en++) {
4
      top = ((en + 1) * 8192) / 256;
5
      hi = (chksum[en] / 256) & 255;
6
      lo = chksum[en] & 255;
7
      target[chklist++] = top;
8
      target[chklist++] = hi;
9
      target[chklist++] = lo;
10
      printf ("%2.2X%2.2X\n", hi, lo);
11
   }
12
   target[i1] = 0;
13
}

von Oliver S. (oliverso)


Lesenswert?

Eine checksum ist selten signed. Also rechne unsigned, und die Warnung 
ist weg.

Oliver

von Yalu X. (yalu) (Moderator)


Lesenswert?

Generell ist man gut beraten, Integer-Divisionen und Right-Shifts nur
auf unsigned-Operanden anzuwenden.

Im konkreten Fall könntest du aber auch
1
  top = ((en + 1) * 8192) / 256;

durch
1
  top = (en + 1) * (8192 / 256);

ersetzen.

von Rolf M. (rmagnus)


Lesenswert?

Bauform B. schrieb:
> Alte Programme provozieren neuerdings Warnungen. Dies ist kein
> unlösbares Problem, mir ist klar, wieso, weshalb, warum.

Dann hätte dir aber eigentlich klar sein müssen, dass die Datentypen der 
Variablen dafür essenziell sind. Du hast allerdings vergessen, uns die 
zu nennen.

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.