-
Data: 2023-02-15 15:40:50
Temat: Re: C++ ośla łączka
Od: Piotr Gałka <p...@c...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2023-02-14 o 22:42, heby pisze:
> Co z grubsza oznacza potrzebę napisania tego w asm.
>
> I tak powinno być.
>
> C nie jest od dłubania po bitach na poziomie arytmetyki asemblera,
> ponieważ stabilność bitu przeniesienia może być związana z
> optymalizacjami czy kolejnością wykonywania wyrażeń.
Tak jak kompilator wie, że optymalizując nie może zrobić najpierw
dodawania a potem mnożenia tak mógłby wiedzieć w którym momencie
wymagane jest wyłuskanie określonego bitu.
> To nie ten poziom abstrakcji.
Na pewno masz rację, ale na przykład skorzystanie z bitu parzystości
uprościło by zapis i przyspieszyło działanie procedury:
int crc16(byte* buf,int n,int crc)// doliczenie n bajtów bufora
{ // Polynomial = x^16+x^15+x^2+1
crc&=0xFFFF;
while(n--)
{
int d=((*(buf++))^crc)&0xFF; // lower crc part
int p=d^(d>>4); p^=p>>2; p^=p>>1; // parity bit
crc= (crc>>8) ^ (d<<7) ^ (d<<6) ^ ((p&1) ? 0xC001 : 0);
}
return crc;
}
Kiedyś dawno (w ubiegłym wieku) sprawdzałem, że działa szybciej niż
standardowy zapis z wewnętrzną pętlą obracania bajtu bit po bicie mimo
konieczności wieloetapowego uzyskiwania bitu parzystości.
W assemblerze ma jeszcze większą przewagę nad zapisem z pętlą bo się po
prostu korzysta z bitu parzystości.
Wtedy szybkość liczenia crc wydawała nam się ważna. Jak potem doszło
szyfrowanie i podpisywanie danych w ramce to czas obliczania crc stracił
na ważności :)
Jestem prawie pewien, że brat sprawdzał, czy kompilator kompilując na
8-bitowy procesor się zorientuje, że całą jedną linijkę może pominąć i
skorzystać z bitu parzystości i prawie na pewno mimo włączonych
wszystkich optymalizacji nie zorientował się.
P.G.
Następne wpisy z tego wątku
- 15.02.23 19:50 heby
- 15.02.23 21:28 Piotr Gałka
- 15.02.23 22:14 Marek
- 15.02.23 23:10 heby
- 16.02.23 00:02 Grzegorz Niemirowski
- 16.02.23 07:22 heby
- 16.02.23 12:46 Grzegorz Niemirowski
- 16.02.23 13:20 Piotr Gałka
- 16.02.23 13:45 heby
- 16.02.23 13:54 heby
- 16.02.23 14:35 J.F
- 16.02.23 15:23 Grzegorz Niemirowski
- 16.02.23 15:33 Piotr Gałka
- 16.02.23 15:37 J.F
- 16.02.23 16:05 Piotr Gałka
Najnowsze wątki z tej grupy
- Schemat automatyki
- Teoretyczne zagadnienie - ogrzewanie budynku
- Zagadka radiowa
- Prostownik
- Nowy akumulator Donut Lab
- Pilot do zamka/bramy
- Jaka myjka ultradźwiękowa?
- Retro organizer ale współcześnie
- Skąd diody LED 1,5V?
- Apollo Comm
- PICkit3 mnie pokonał
- LEDy na choinkę zdechły
- Wtopa LED
- Miało być zniesienie abonamentu RTV, a jest podwyżka!!!
- Microsoft, C/C++ na Rust - news
Najnowsze wątki
- 2026-01-14 Do Kongresu SZAP/USONA Złożono Proj. ,,Ustawy o aneksji i statusie stanowym Grenlandii"
- 2026-01-13 STREFA CZYSTEGO TRANSPORTU. O tym nie mówią nam WŁADZE
- 2026-01-13 To nie koniec
- 2026-01-13 Warszawa => Recruiter 360 <=
- 2026-01-13 Katowice => Key Account Manager <=
- 2026-01-13 Warszawa => Senior Backend Java Developer <=
- 2026-01-13 Wrocław => ERP Implementation Consultant <=
- 2026-01-13 Elektryk a otwieranie drzwi :-)
- 2026-01-12 Schemat automatyki
- 2026-01-12 Xiaomi [Chiny - przyp. JMJ] produkuje w całkowitych ciemnościach i bez ludzi
- 2026-01-12 Polska Grupa Zbrojeniowa (85% udziałów) Likwiduje Stomil-Poznań - Zakład Działał Od 1928r.
- 2026-01-12 Teoretyczne zagadnienie - ogrzewanie budynku
- 2026-01-12 Xiaomi [Chiny - przyp. JMJ] produkuje w całkowitych ciemnościach i bez ludzi
- 2026-01-12 Xiaomi [Chiny - przyp. JMJ] produkuje w całkowitych ciemnościach i bez ludzi
- 2026-01-12 Polska Grupa Zbrojeniowa (85% udziałów) Likwiduje Stomil-Poznań - Zakład Działał Od 1928r.




5 Najlepszych Programów do Księgowości w Chmurze - Ranking i Porównanie [2025]