-
Data: 2023-02-13 09:26:12
Temat: Re: C++ ośla łączka
Od: jacek pozniak <j...@f...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Piotr Gałka wrote:
> Kiedyś dawno (trochę dla sportu) na podstawie dokumentów NIST napisałem
> (C++) swoje procedury dla DES, AES, SHA, CMAC, HMAC.
> Potem jak doszliśmy do szyfrowania komunikacji brat przepisał je na
> assembler i na C.
> Według tego co wiem od brata (piszę o czymś o czym mam blade pojęcie) w
> przypadku AtXmega (nie ma wbudowanego SHA) napisanie w assemblerze daje
> kilkukrotną przewagę nad napisaniem w C. Ja to rozumiem tak, że C
> blokuje 'dla siebie' ileś rejestrów, a żeby policzyć SHA256 bez ciągłego
> przewalania danych między rejestrami a pamięcią trzeba wykorzystać
> praktycznie wszystkie rejestry procesora. SHA512 już się tak nie da
> napisać i różnica między C a assemblerem będzie mniejsza.
Jak dobry kompilator to sobie jakoś radzi, jak gorszy to gorzej.
Czasami w asemblerze można coś bardziej zwarcie napisać.
Jednak w dłuższej perspektywie, pisanie w asm to strata czasu i proszenie
się o kłopoty; zmienia się platforma i musisz
pisać/testować/poprawiać/testować itd, od nowa.
Jeśli procesor już nie radzi sobie z zagadnieniem to trzeba wziąć większy
procesor zamiast schodzić do asemblera.
jp
>
> Opis jak się liczy AES-a zrozumiałem na tyle dobrze, że używane tam
> tabele wygenerowałem sobie z równań, aby nie ryzykować błędem przy
> przepisywaniu, ale dlaczego rozszyfrowywanie nie robione metodą 'do
> tyłu' tylko 'inaczej do przodu' daje to samo od czego zaczęliśmy to już
> nie całkiem ogarniam.
> Chciałbym jeszcze kiedyś na tym samym poziomie zrozumieć wykorzystanie
> krzywych eliptycznych w kryptografii niesymetrycznej. Czyli nie
> koniecznie jaka matematyka za tym stoi, ale jak to policzyć z
> dokładnością do każdego bitu.
>
> Są może gdzieś jakieś przykłady?
> P.G.
--
jp
www.flowservice.pl
www.flowsystem.pl
Następne wpisy z tego wątku
- 14.02.23 15:39 Piotr Gałka
- 14.02.23 19:06 Janusz
- 14.02.23 22:22 Piotr Gałka
- 14.02.23 22:42 heby
- 15.02.23 15:40 Piotr Gałka
- 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
Najnowsze wątki z tej grupy
- System operacyjny dla 6800?
- Przyłączenie działki do sieci elektrycznej
- Działalność nierejestrowana/definicja sprzętu elektronicznego/misie i kolejki
- Smukły, długi ściągacz izolacji do kynaru
- rezystor 3 omy 400W
- [newbie] Jaki multimetr za 2-4 stówy?
- szafka sieciowa
- Raspberry Pi 5 + dyski SATA
- lutownica na węgiel
- Znów czary (albo niewiedza) - tym razem fotowoltaika
- Chess
- Vitruvian Man - parts 7-11a
- przeźroczyste koszulki
- Re: Win 10/11 nie lubi OKI
- Programator czasowy TUYA.
Najnowsze wątki
- 2024-05-18 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-18 Warszawa => Software .Net Developer <=
- 2024-05-18 Warszawa => Mid/Senior QA Engineer <=
- 2024-05-18 Ulm => Solution Architect (sichere Kommunikation und IoT-Loesungen <=
- 2024-05-18 Katowice => Head of Virtualization Platform Management and Operating S
- 2024-05-18 Warszawa => SAP WM Consultant / Execution <=
- 2024-05-18 Wrocław => Consultant/Implementer Comarch ERP XL <=
- 2024-05-18 Gdańsk => Head of International Freight Forwarding Department <=
- 2024-05-18 Warszawa => Account Manager (Recruitment Services) <=
- 2024-05-18 Łódź => Salesperson - CRM Systems <=
- 2024-05-18 Łódź => Handlowiec - Systemy CRM <=
- 2024-05-17 ZŁOMNIK o pracy w TVN TURBO, nowych przepisach i współczesnej motoryzacji. Turbo Taryfa!
- 2024-05-17 Białystok => DevOps Engineer Conexa First (Contractor) <=
- 2024-05-17 Warszawa => Starszy inżynier oprogramowania (Rust) <=
- 2024-05-17 Zabrze => Junior HelpDesk <=