Czy w przypadku jądra Linuksa strony "Kernel" zostaną kiedykolwiek zamienione? Czy strony przestrzeni użytkownika mogą znajdować się w ZONE_NORMAL?Czy strony jądra są zamieniane?
Odpowiedz
Nie, pamięć jądra jest niewymienna.
Strony jądra nie można wymieniać. Ale można go uwolnić.
Strony UserSpace mogą znajdować się w strefie ZONE_NORMAL. System Linux Można skonfigurować tak, aby używał HIGHMEM lub nie. Jeśli skonfigurowano ZONE_HIGHMEM, to procesy przestrzeni użytkownika otrzymają swoją pamięć z HIGHMEM, podczas gdy inne procesy przestrzeni użytkownika otrzymają pamięć z ZONE_NORMAL.
Tak, w normalnych warunkach nie są wymienialne podczas pracy, w rzeczywistości, po wykryciu stron jądra (czyli pamięć zamieszkały w jądrze za korzystanie jądra) (patrz kod pagefault źródłowy handler), jądro będzie wyraźnie rozbić się .
Zobacz to:
http://lxr.free-electrons.com/source/arch/x86/mm/fault.c
i funkcji:
1205 /*
1206 * This routine handles page faults. It determines the address,
1207 * and the problem, and then passes it off to one of the appropriate
1208 * routines.
1209 *
1210 * This function must have noinline because both callers
1211 * {,trace_}do_page_fault() have notrace on. Having this an actual function
1212 * guarantees there's a function trace entry.
1213 */
1214 static noinline void
1215 __do_page_fault(struct pt_regs *regs, unsigned long error_code,
1216 unsigned long address)
1217 {
oraz wykrywania tutaj:
1246 *
1247 * This verifies that the fault happens in kernel space
1248 * (error_code & 4) == 0, and that the fault was not a
1249 * protection error (error_code & 9) == 0.
1250 */
1251 if (unlikely(fault_in_kernel_space(address))) {
1252 if (!(error_code & (PF_RSVD | PF_USER | PF_PROT))) {
1253 if (vmalloc_fault(address) >= 0)
1254 return;
1255
1256 if (kmemcheck_fault(regs, address, error_code))
1257 return;
1258 }
Ale same procedury obsługi pagefault - który może wykryć pagefault wynikające z nieistniejącej pamięci trybu użytkownika (cały sprzęt detekcyjny pagefault ement jest zawsze wykonywany w jądrze) jawnie pobierze dane z obszaru wymiany, jeśli istnieje, lub uruchomi procedurę przydzielania pamięci, aby nadać procesowi więcej pamięci.
Ok, powiedział, że kernel robi swap struktury jądra/pamięć/tasklists etc podczas oprogramowania zawieszenia i hibernacji praca:
https://www.kernel.org/doc/Documentation/power/swsusp.txt
I fazie CV będzie przywrócić z powrotem pamięć jądra z wymiany plik.
- 1. Czy jądra jądra systemu Linux są zamienione na dysk?
- 2. Po obrocie współrzędne UIView są zamieniane, ale UIWindow nie są?
- 3. Czy odniesienia jądra jądra liczą obiekty jądra?
- 4. Zrzuty jądra Linuksa są zbyt duże!
- 5. Czy w ASP.NET MVC są zagnieżdżone strony wzorcowe?
- 6. Jaki rozmiar są liczbami całkowitymi podczas programowania jądra cuda
- 7. Czy stdio można używać podczas kodowania jądra ...?
- 8. Zmień timer jądra Linuksa
- 9. Instalacja jądra Java JRE?
- 10. Android: Jak zdobyć dzienniki jądra po awarii jądra?
- 11. Czy ograniczenie (wzmacniacz) jest bardziej restrykcyjne niż kod jądra CUDA?
- 12. Czy używanie parametrów jądra może powodować konflikty bankowe?
- 13. disable_local_irq i jądra czasomierze
- 14. Jak konstruować duże jądra OpenCL?
- 15. Funkcjonalność jądra linuksa
- 16. Moduły jądra Linux - zagrożenie bezpieczeństwa?
- 17. Funkcja mprotect() podobna do jądra Linuksa
- 18. Resetowanie jądra ipython
- 19. Przenoszenie jądra do innej architektury?
- 20. Nazwa wersji jądra Androida
- 21. Relacyjna implementacja jądra Fisher
- 22. Rozdzielczość jądra w python nltk przy użyciu jądra StanfordNLP
- 23. Notatnik Jupytera martwego jądra
- 24. Programowanie jądra Linuksa: makefile
- 25. Kompilacja jądra z AOSP
- 26. Awaria jądra Jupytera R
- 27. Niepowodzenie kompilacji jądra Linuksa
- 28. Czy możemy wywołać wywołanie systemowe w przestrzeni jądra?
- 29. Czy można wyładować sterownik jądra bez ponownego uruchomienia?
- 30. Czy jest konieczne użycie kthread_stop, jeśli wrócimy z wątku jądra?
Co ze stronami przydzielonymi przez sterowniki? –