abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 22:22 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za duben (YouTube).

    Ladislav Hagara | Komentářů: 0
    včera 19:11 | IT novinky

    Provozovatel čínské sociální sítě TikTok dostal v Evropské unii pokutu 530 milionů eur (13,2 miliardy Kč) za nedostatky při ochraně osobních údajů. Ve svém oznámení to dnes uvedla irská Komise pro ochranu údajů (DPC), která jedná jménem EU. Zároveň TikToku nařídila, že pokud správu dat neuvede do šesti měsíců do souladu s požadavky, musí přestat posílat data o unijních uživatelích do Číny. TikTok uvedl, že se proti rozhodnutí odvolá.

    Ladislav Hagara | Komentářů: 2
    včera 11:22 | Zajímavý projekt

    Společnost JetBrains uvolnila Mellum, tj. svůj velký jazykový model (LLM) pro vývojáře, jako open source. Mellum podporuje programovací jazyky Java, Kotlin, Python, Go, PHP, C, C++, C#, JavaScript, TypeScript, CSS, HTML, Rust a Ruby.

    Ladislav Hagara | Komentářů: 1
    včera 09:11 | Bezpečnostní upozornění

    Vývojáři Kali Linuxu upozorňují na nový klíč pro podepisování balíčků. K původnímu klíči ztratili přístup.

    Ladislav Hagara | Komentářů: 0
    1.5. 20:00 | Komunita

    V březnu loňského roku přestal být Redis svobodný. Společnost Redis Labs jej přelicencovala z licence BSD na nesvobodné licence Redis Source Available License (RSALv2) a Server Side Public License (SSPLv1). Hned o pár dní později vznikly svobodné forky Redisu s názvy Valkey a Redict. Dnes bylo oznámeno, že Redis je opět svobodný. S nejnovější verzí 8 je k dispozici také pod licencí AGPLv3.

    Ladislav Hagara | Komentářů: 1
    1.5. 19:22 | IT novinky

    Oficiální ceny Raspberry Pi Compute Modulů 4 klesly o 5 dolarů (4 GB varianty), respektive o 10 dolarů (8 GB varianty).

    Ladislav Hagara | Komentářů: 0
    30.4. 22:33 | Nová verze

    Byla vydána beta verze openSUSE Leap 16. Ve výchozím nastavení s novým instalátorem Agama.

    Ladislav Hagara | Komentářů: 0
    30.4. 17:44 | Zajímavý článek

    Devadesátková hra Brány Skeldalu prošla portací a je dostupná na platformě Steam. Vyšel i parádní blog autora o portaci na moderní systémy a platformy včetně Linuxu.

    karkar | Komentářů: 0
    30.4. 12:11 | Humor

    Lidi dělají divné věci. Například spouští Linux v Excelu. Využít je emulátor RISC-V mini-rv32ima sestavený jako knihovna DLL, která je volaná z makra VBA (Visual Basic for Applications).

    Ladislav Hagara | Komentářů: 7
    30.4. 10:44 | IT novinky

    Revolut nabídne neomezený mobilní tarif za 12,50 eur (312 Kč). Aktuálně startuje ve Velké Británii a Německu.

    Ladislav Hagara | Komentářů: 36
    Jaký filesystém primárně používáte?
     (58%)
     (1%)
     (9%)
     (21%)
     (4%)
     (1%)
     (2%)
     (0%)
     (1%)
     (3%)
    Celkem 506 hlasů
     Komentářů: 19, poslední 30.4. 11:32
    Rozcestník

    Mám 4 GB RAM ale dostupné paměti mám méně

    Původní dotaz se týkal SuSE 10.2 pro platformu x86_64, základní desky Gigabyte 965P-DS3, CPU-C2D E6300. Po rozšíření RAM z 2 GB na 4 GB přestal linux startovat. Pomohlo přidání bootovacího parametru mem=4G kernelu. Při zjišťování dostupné paměti RAM ale různé programy ukazovaly hodnotu pouze 3,74 GB. Příklad výpisu z dmesg:
    BIOS-provided physical RAM map:
    BIOS-e820: 0000000000000000 - 000000000009f800 (usable)
    BIOS-e820: 000000000009f800 - 00000000000a0000 (reserved)
    BIOS-e820: 00000000000f0000 - 0000000000100000 (reserved)
    BIOS-e820: 0000000000100000 - 00000000dfd78000 (usable)
    BIOS-e820: 00000000dfee0000 - 00000000dfee3000 (ACPI NVS)
    BIOS-e820: 00000000dfee3000 - 00000000dfef0000 (ACPI data)
    BIOS-e820: 00000000dfef0000 - 00000000dff00000 (reserved)
    BIOS-e820: 00000000f0000000 - 00000000f4000000 (reserved)
    BIOS-e820: 00000000fec00000 - 0000000100000000 (reserved)
    BIOS-e820: 0000000100000000 - 0000000120000000 (usable)
    
    Všimněte si, že north bridge prokládá úseky použitelné RAMky jinými úseky, do kterých jsou mapované různé IO funkce. A pokud správně koukám, v mapě zbyl i nějaký „vzduch”. Takže kus použitelné RAMky přeteče přes 4 GB. Shodou okolností to podle mého odpovídá tomu poslednímu úseku, tj. 0,5 GB od 0x100000000 výše. Podle mého, pokud Vy kernelu nastavíte strop na 4 GB, tak oříznete tu oblast fyzického adresního prostoru CPU, co je hardwarem mapována nad 4 GB, takže zůstane nevyužita. Dokumentace kernelu je sice v tomto bodě dost mlhavá, mluví obvykle o „system memory”, takže není jasné, zda se mluví o RAMce nebo o „fyzickém adresním prostoru CPU“ (adresa určená piny A0-A35 v patici procesoru). Podle mého z této situace plyne, že kernelovým command-line argumentem mem=4G omezíte nikoli RAMku, ale fyzický adresní prostor. Svého času jsem narazil na problém, že některé čipsety od Intelu, přestože podporují CPU s fyzickým adresním prostorem 36 bitů (ať už přes PAE nebo EM64T), mají z north bridge nadrátováno pouze 32 adresních bitů, takže de facto mrzačí fyzický adresní prostor CPU na 4 GB. Týká se to konkrétně jednoprocesorových čipsetů i915, i925 a i7221 (P4/LGA775). Tenhle problém se v úvodu zmíněné základní desky netýká (C2D a i965 umí 36 bitů), což ostatně dokazuje i BIOSem sdělená mapa e820 – u výše uvedených čipsetů nepřekročí hranici 4 GB neboli 0x100000000. Dostal jsem tehdy od výrobce motherboardu jakési postarší PDFko od Intelu, které je dnes už spíše archivní (rok 2004), nicméně je značeno „Intel Confidential” a nikde na webu jsem ho nevygoogloval, takže si nedovolím ho zveřejnit, přestože je v podstatě neškodné. Nicméně přikládám alespoň tabulku, kde jsou hezky vidět různě velké kusy rezervovaného fyzického adresního prostoru. Podle údajů z té tabulky bych řekl, že 512 MiB je zabráno převážně PCI a PCI-e config spacem. Řekl bych, že výše zmíněný čipset s adresním prostorem zachází ještě vcelku ohleduplně, s ohledem na to, že pro něj 4GB hranice nepředstavuje problém :-) Co s tím dál? Pro mne z výše uvedeného plyne, že za tuto situaci možná nemůže hardware ani BIOS. (Přesto bych se zkusil podívat po novější verzi BIOSu, člověk nikdy neví. Může to mít nějakou vazbu na ACPI bugy při konfiguraci PCI apod.) Kdo za to může: nevylučuji, že za to může kernelový ovladač nějakého PCI zařízení, který není 64bit ready, a sáhne v paměti někam, kam nemá. Nebo to teoreticky může být problém někde uvnitř nejintimnějších vnitřností Linuxu, v oblasti správy paměti a mapování PCI MMIO oblastí, PCI DMA apod. Tomu ale moc nevěřím… Nejsem natolik zběhlý v oblasti PCI, abych dokázal říct, jestli to může být třeba chybou hardwaru PCI periferie, která umí pouze 32bitovou adresaci DMA přenosů (přestože PCI i 32bitová už nějakou dobu umí 64bitovou adresaci, pomocí „dual address cycle”), zda vůbec Linux podporuje PCI DMA do „high memory” apod. Ona taky adresace PCI není 1:1 s adresací hostitele, opět je tam nějaké mapování, takže těžko říct, zda se tento druh chyby může uplatnit. Každopádně se zdá, že pokud kernelu vnutíte omezení na 32bitový fyzický adresní prostor, tak se mu hračky nerozkutálejí… Pokud máte čas a náladu to trápit, zkusil bych možná:
    • jiné 64b distro (Fedora/RedHat/Centos?), které může mít jinou sadu patchů
    • zkompilovat si svůj vlastní např. vanilkový kernel, ze kterého vyházíte všechny ovladače, kromě těch nejnutnějších: initial ramdisk, řadič disku tj. IDE, Intel SATA a AHCI, povinné filesystémy, další features potřebné pro danou distribuci
    Souhlasím, že by bylo dobře vědět, kde přesně se kernel při bootu zasekne. Je možné, že místo záseku poukáže až na druhotný problém, způsobený někde dřív, ale velmi často to odpovídá poměrně přesně. Pokud si zkompilujete vanilkový kernel, a třeba se Vám s ním i nepodaří nabootovat distro (třeba ani nenamountuje root), pořád aspoň uvidíte, jestli se Vám v neomezeném 64b režimu na daném hardwaru dostal alespoň přes to místo, kde Vám Suse kernel zůstává viset. Taky by se dala zapnout konzola na sériovém portu a típnout boot log z toho vadného pokusu… Že na tom Windows Vista hlásí celé 4 GB RAM, to je podle mého v pořádku, a nevylučuje to binec v linuxovém kernelu (ať už původem od Suse nebo původem z vanilky) ani binec v ACPI BIOSu toho hardwaru. Mimochodem, zkuste taky kernel boot parametr irqpoll – šance, že za to můžou IRQčka, je poměrně malá, ale za vyzkoušení nic nedáte.
    Text je původně diskuzním příspěvkem Františka Ryšánka v odpovědi na dotaz Mam 4GB RAM ale mam dostupne iba 3.76GB .

    Dokument vytvořil: Filip Jirsák, 7.8.2007 13:53 | Poslední úprava: Käyttäjä 11133, 12.8.2007 13:44 | Další přispěvatelé: Filip Jirsák | Historie změn | Zobrazeno: 1490×

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.