Hexspeak - Hexspeak

Hexspeak, jako leetspeak, je nová forma varianty Angličtina pravopis pomocí hexadecimálních číslic. Vytvořili programátoři jako nezapomenutelné magická čísla, hexspeak slova mohou sloužit jako jasný a jedinečný identifikátor, kterým lze označit paměť nebo data.

Hexadecimální notace představuje čísla pomocí 16 číslic 0123456789ABCDEF. Používá pouze písmena A B C D E F je možné hláskovat několik slov. Další slova lze vytvořit zpracováním některých desetinných čísel jako písmen - číslice "0„může představovat písmeno„ O “a„1„může představovat písmena„ I “nebo„ L “. Méně často,“5"může představovat" S ","7"reprezentovat" T ","12„představují„ R “a„6„nebo“9"může představovat" G "nebo" g ". Čísla jako 2, 4 nebo 8 lze použít podobným způsobem jako leet nebo slevy; např. slovo „defekovat“ lze vyjádřit buď jako DEFECA7E nebo DEFEC8.

Pozoruhodná magická čísla

Mnoho počítačové procesory, operační systémy, a debuggery využívat magická čísla, zejména jako a magická hodnota ladění.

KódDesetinnýPopis
0x0000000FF1CE1044942(„kancelář“) se používá jako poslední část kódů produktu (GUID ) pro Microsoft Office komponenty (viditelné v registru pod klíčem HKLM SOFTWARE Microsoft Windows CurrentVersion Uninstall registru).
0x00BAB10C12235020("über (ooba) blok") se používá jako magické číslo pro ZFS uberblock.
0x1BADB002464367618("1 špatný boot"[1]) Magické číslo záhlaví Multiboot.[2]
0x4B1D19229(„forbid'den '“) bylo heslo v některých kalibračních konzolách pro vývojáře, aby nahlédli hlouběji do řídicích registrů mimo normální rozsah kalibrační paměti.[Citace je zapotřebí ]
0x8BADF00D2343432205(„jedl špatné jídlo“) používá Jablko v iOS zprávy o selhání, když aplikaci trvá příliš dlouho, než se spustí, ukončí nebo reaguje na systémové události.[3]
0xABADBABE2880289470(„a bad babe“) byl / je používán Windows 7 od Microsoftu ke spuštění bodu zlomu debuggeru, pravděpodobně když je připojeno USB zařízení[4]
0xB105F00D2969956365(„BIOS food“) je hodnota nízkých bajtů posledních čtyř registrů na komponentách kompatibilních s ARM PrimeCell (registry component_id), které se používají k identifikaci správného chování komponenty mapované do paměti.
0xB16B00B52976579765(„velká prsa“) požadoval uživatel Microsoft je Hyper-V hypervisor, který mají hosté Linuxu používat jako svůj „podpis hosta“.[5] Jeden návrh navrhl změnit na 0x0 DEFACED („poškozeno“).[6] Ve skutečnosti to však bylo původně změněno na desítkové a poté úplně nahrazeno.[7]
0x0B00B135184594741("prsa") byla rovněž požadována Microsoft je Hyper-V hypervisor, který bude používán uživatelem XEN jako jeho ID uživatele.[8] To bylo odstraněno 22. ledna 2010. [9]
0xBAAAAAAD3131746989(„baaaaaad“) používá Jablko je iOS zpráva o výjimce, která označuje, že protokol je stohem celého systému, nikoli zprávou o selhání.[10]
0xBAADF00D3131961357(„špatné jídlo“) používá Microsoft 'LocalAlloc (LMEM_FIXED) k označení neinicializované alokované paměti haldy při použití haldy ladění.[11]
0xBAD222223134333474(„špatně příliš opakovaně“) používá Jablko je iOS protokol výjimek, který označuje, že aplikace VoIP byla iOS ukončena, protože byla obnovena příliš často.[10]
0xBADDCAFE3135097598(„špatná kavárna“) používá Libumem k označení neinicializované oblasti paměti.
0xBEEFBABE3203381950(„beef babe“) používá Frogger (1997 videohra) detekovat a přetečení vyrovnávací paměti zásobníku.
0xB000 0xDEAD2952847021("boo mrtvý") byl zobrazen pomocí HP 9000 Model 840, když havaroval.[Citace je zapotřebí ]
0xC00010FF3221229823("vychladnout") používá Jablko v iOS zprávy o selhání, když byla aplikace zabita v reakci na tepelnou událost.[3]
C15C: 0D06: F00D212601099710477("cisco krmivo pro psy") používané v EU IPv6 adresa z www.cisco.com na Světový den IPv6. „Krmivo pro psy“ označuje společnost Cisco jíst své vlastní krmivo pro psy s IPv6.
0xCAFEBABE3405691582(„cafe babe“) používá Plán 9 libc jako jedová hodnota pro paměťové fondy.[12] Používá ji také Mach-O identifikovat Univerzální soubory objektů a Programovací jazyk Java identifikovat Bajtový kód Java soubory třídy. To bylo původně vytvořeno Další krok vývojáři jako odkaz na baristy na Peetova káva a čaj.[13]
0xCAFED00D3405697037(„cafe dude“) používá Jáva jako magické číslo pro jejich pack200 komprese.[14]
0xCEFAEDFE3472551422("feed obličeje") používá Mach-O k identifikaci plochých (jednoarchitektonických) objektových souborů. v malý Endian toto zní FEEDFACE„Feed Face“.
0x0D15EA5E219540062("zero disease") je příznak, který označuje pravidelné spuštění systému Nintendo GameCube a Wii konzoly.[15][16]
0xDABBAD003669732608(„dabba doo“) je název blogu o počítačové bezpečnosti.[17]
0xDEAD2BAD3735890861(„Dead too bad“) byl použit k označení přidělených oblastí paměti, které ještě nebyly inicializovány Následující Dynix / ptx systémy.
0xDEADBAAD3735927469("dead bad") se používá funkcí Android libc abort (), když je zjištěno poškození nativní haldy.
0xDEADBABE3735927486(„dead babe“) používá IBM Jikes RVM jako kontrola zdravého rozumu zásobníku primárního vlákna.[18]
0xDEADBEAF3735928495("mrtvý beaf") je součástí podpisového kódu Jazz Jackrabbit 2 soubory dlaždic.[19] Soubory úrovně mají menší prostor pro jejich podpisy a použití 0xBABE („kotě“).[20] Je také záhlaví herních kampaní používaných v herní sérii Halo.
deadbeef-dead-beef-dead-beef00000075("mrtvé hovězí maso") je GUID přidělen k pověšení / smrti virtuální stroje v Citrixu XenServer.
0xDEADBEEF3735928559(„mrtvé hovězí maso“) se často používá k označení selhání nebo zablokování softwaru ve vestavěných systémech. 0xDEADBEEF se původně používalo k označení nově přidělených oblastí paměti, které ještě nebyly inicializovány - při skenování výpisu paměti je snadné vidět 0xDEADBEEF. Používá ji IBM RS / 6000 systémy, Operační Systém Mac na 32-bit PowerPC zpracovatelé a Komodor Amiga jako magická hodnota ladění. Na Sun Microsystems ' Solaris, označuje uvolněnou paměť jádra. Na OpenVMS běží na procesorech Alpha, 0xDEADBEEF lze zobrazit stisknutím kláves CTRL-T. Konzole DEC Alpha SRM má proces na pozadí, který zachycuje chyby paměti, identifikovaný PS jako „BeefEater čekající na 0xdeadbeef“.[21]
0xDEADC0DE3735929054("mrtvý kód ") se používá jako značka v OpenWrt firmware označuje začátek budoucího vytvořeného souborového systému jffs2 na konci statického firmwaru.
0xDEADDEAD3735936685("mrtvý mrtvý") je kód kontroly chyby (STOP) zobrazený při vyvolání a Modrá obrazovka smrti buď sdělením jádru prostřednictvím připojeného debuggeru, nebo pomocí speciální kombinace kláves.[22] To obvykle vidí vývojáři ovladačů, protože se používá k získání výpisu paměti v systémech založených na Windows NT. Alternativa k 0xDEADDEAD je kód pro kontrolu chyb 0x000000E2,[23] jak se oba nazývají MANUALLY_INITIATED_CRASH, jak je vidět na síti Microsoft Developer Network.
0xDEADD00D3735932941(„mrtvý vole“) používá Android v Virtuální stroj Dalvik k označení přerušení VM.
0xDEADFA113735943697("mrtvý pád" nebo "mrtvý selhání") používá Jablko v iOS zprávy o selhání, když síla uživatele ukončí aplikaci.[3]
0xDEAD10CC3735883980("mrtvý zámek") používá Jablko v iOS zprávy o selhání, když se aplikace drží na zdroji systému, když běží na pozadí.[3]
0x DEADFEED3735944941("mrtvý zdroj") používá Jablko v iOS zprávy o selhání, když dojde k vypršení časového limitu pro vytvoření služby
0xDECAFBAD3737844653(„bez kofeinu“) se v kódování často vyskytuje jako snadno rozpoznatelné magické číslo při hex dumpingové paměti
0x DEFEC8ED3741239533("defecated") je magické číslo pro OpenSolaris skládky jádra.[24]
0xD0D0CACA3503344330("doo-doo caca ") je neinicializovaná hodnota hodnot GPIO na Nvidia Tegra X1[Citace je zapotřebí ]
0xE011CFD03759263696("docfile0") se používá jako magické číslo pro soubory Microsoft Office. v malý Endian toto zní D0CF11E0„docfile0“.[25]
obličej: b00c4207849484("Facebook ") použitý v IPv6 adresy z www.facebook.com.[26]
0xFACEFEED4207869677(„face feed“) používají servery Alpha se systémem Windows NT. Alfa Hardwarová abstrakční vrstva (HAL) generuje tuto chybu, když narazí na selhání hardwaru.[27]
0xFBADBEEF4222467823("bad beef") se používá v WebKit a Blikat rozložení motory k označení známé, neodstranitelné chyby, jako je nedostatek paměti.[28]
0xFEE1DEAD4276215469("Feel Dead") se používá jako magické číslo v Linux restartujte systémové volání.[29]
0xFEEDBABE4276992702("feed babe") je magické číslo používané k označení začátku OpenRG deskriptor flash oddílu.[30]
0xFEEDC0DE4276994270("feed feed") se používá jako vzor vyplnění OS-9 Operační systém při inicializaci jeho RAM.[31]
0xFEEDFACECAFEBEEF18369614221190020847(„feed face cafe beef“) je magické číslo, které se používá k odeslání jako heslo sériovým kabelem k záchraně některých zařízení řadiče vytvořených pomocí NXP před selháním bootování.[32][33][34]
0xFFBADD114290436369("špatný DLL "): Používá Okna vnitřně.[Citace je zapotřebí ]

Alternativní písmena

Mnoho počítačových jazyků vyžaduje, aby bylo hexadecimální číslo označeno předponou nebo příponou (nebo oběma), aby bylo možné jej identifikovat jako číslo. Někdy se předpona nebo přípona používá jako součást slova.

  • The Programovací jazyk C. používá předponu „0x“ k označení hexadecimálního čísla, ale „0x“ je obvykle ignorována, když lidé čtou takové hodnoty jako slova. C také umožňuje příponu L deklarovat celé číslo jako dlouho, nebo LL deklarovat jako dlouho dlouho, což umožňuje psát "0xDEADCELL" (mrtvá buňka). V obou případech se U může také objevit v příponě, která deklaruje celé číslo jako nepodepsaný, což umožňuje psát "0xFEEDBULL" (feed bull).
  • V (non-Unix) Montážní jazyk Intel, hexadecimální čísla jsou označena příponou „h“, což umožňuje psát „0beach“ (pláž). Všimněte si, že čísla v tomto zápisu, která začínají písmenem, musí mít předponu nulu, aby se odlišily od názvů proměnných. Místo toho používá assembler ve stylu Unixu jazykovou konvenci C (ale v operačních systémech typu x86 Unix jsou k dispozici také asemblery jiného než Unix).
  • Visual Basic a všechny předchozí Microsoft BASIC, jako QuickBasic, GWBasic, BASICA a ColorBASIC, používají předponu & H, například „& HEADED“ (hlavička) a „& HADC0FFEE“ (káva).
  • V Pascalu a několika montážní jazyky (6502,6809, ...), hexadecimální čísla jsou označena předponou „$“. To umožňuje slova začínající písmenem „S“, například „$ EED“ (seed).
  • v Б3-34 programovatelné kalkulačky, byla použita alternativní hexadecimální abeceda, kde místo latinských písmen byly použity symboly „-“, „L“, „C“, „Г“, „E“ a „“ (mezera). Pomocí nich bylo možné zobrazit zprávy jako „EГГ0Г“ (chyba).

PlayStation 3 RSX

V oblasti reverzního inženýrství společnosti Sony PlayStation 3 Bylo zjištěno, že řada hexspeakových kódů buď spouští, ovlivňuje nebo byla přítomna v aspektech komunikace s hypervizorem PlayStation 3 a prostřednictvím něj v komunikaci s jeho GPU, Syntezátor reality RSX.[35]

Tyto projekty se z velké části zrodily z PS3 homebrew fungujících na PS3 OtherOS což umožnilo instalaci Linuxu, zpočátku s extrémně omezeným přístupem GPU.

KódPopis
0x1337BEEF, 0x1337F001, 0x1337BEEFNalezeno jako součást deskriptoru RSX.
0xF00DBEEFHodnota semaforu RSX
0x1337C0D3 a 0x1337BABEZačněte semaforovou hodnotu a pad ze systému.[36]

Viz také

Reference

  1. ^ "Archiv seznamů adres pro více bootů".
  2. ^ "Specifikace multibootu".
  3. ^ A b C d „Technická poznámka TN2151: Porozumění a analýza hlášení o selhání aplikace pro iPhone OS“. Archivovány od originál dne 05.07.2012.
  4. ^ „Kdo je 0xabadbabe a proč?“.
  5. ^ "Fáze: hv: vmbus_drv: Přesunout obsah hv.h do hyperv_vmbus.h".
  6. ^ „hv: Změnit hodnotu ID hosta“.
  7. ^ https://github.com/torvalds/linux/commit/83ba0c4f3f317270dae5597d8044b795d119914c
  8. ^ „Staging: hv: add the Hyper-V virtual bus“.
  9. ^ „Staging: hv: Odstranit starší kód xen a zkontrolovat Hyper-V“.
  10. ^ A b https://developer.apple.com/library/ios/technotes/tn2151/_index.html
  11. ^ "Interní haldy ladění Win32 CRT".
  12. ^ „9front system“.
  13. ^ „Proč Cafebabe“. Artima.com. Citováno 2009-10-01.
  14. ^ „Pack200: Složený formát nasazení třídy pro aplikace Java“. Citováno 2010-11-03.
  15. ^ „Ještě další dokumentace GameCube: Globální systémy Dolphin-OS“.
  16. ^ „Wiibrew: Memory Map“.
  17. ^ „0xdabbad00.com“.
  18. ^ „DEADBABE sanity check“. Citováno 2009-10-01.[trvalý mrtvý odkaz ]
  19. ^ "Formát souboru J2T".
  20. ^ "Formát souboru J2L".
  21. ^ „Položka žargonu pro DEADBEEF“. Catb.org. Citováno 2009-10-01.
  22. ^ „Kontrola chyby 0xDEADDEAD: MANUALLY_INITIATED_CRASH, MSDN“. msdn.microsoft.com. 2009-10-01. Archivovány od originál 2. října 2009. Citováno 2009-10-13.
  23. ^ „Kontrola chyby 0xE2: MANUALLY_INITIATED_CRASH, MSDN“. msdn.microsoft.com. 2009-10-01. Archivovány od originál dne 31. července 2009. Citováno 2009-10-13.
  24. ^ „Řádek záhlaví Opensolaris 45 pro 0xDEFEC8ED“. src.opensolaris.org. Archivovány od originál dne 29. 9. 2011. Citováno 2011-07-12.
  25. ^ „Dokumenty podporované filtrem Office“.
  26. ^ „Facebook vrhá hex se samoreferenčním IPv6“. Citováno 2017-10-21.
  27. ^ „Článek Technet pro 0xFACEFEED“. Support.microsoft.com. 2006-11-01. Citováno 2009-10-01.
  28. ^ "Chromium Assertions.h řádek 133". Citováno 2014-03-27.
  29. ^ „include / linux / reboot.h“.
  30. ^ „OpenWrt-Devel: PATCH - přidat podporu pro Option GlobeSurfer 3“. Archivovány od originál dne 2016-03-29. Citováno 2015-12-14.
  31. ^ „Instalační příručka OEM OS-9 pro procesory 68K“.
  32. ^ „Poznámka k aplikaci NXP: Aplikace modulu Qorivva Boot Assist Module“ (PDF).
  33. ^ „Komunita NXP: Cenzurované zařízení - známé heslo“.
  34. ^ „Komunita NXP: chyba zavaděče RAppID“.
  35. ^ „RSXFIFOCommands - PS3 Developer Wiki“. psdev wiki. 20. 05. 2014. Citováno 2017-11-01.
  36. ^ „rpc3 / sys_rsx.cpp“. RPCS3 na github. 2017-10-28. Citováno 2017-11-01.

externí odkazy