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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 16:00 | Nová verze

Byla vydána verze 0.98 svobodného nelineárního video editoru Pitivi. Z novinek lze zmínit například přizpůsobitelné klávesové zkratky. Videoukázka práce s nejnovější verzí Pitivi na YouTube.

Ladislav Hagara | Komentářů: 0
dnes 15:00 | Zajímavý software

Stop motion je technika animace, při níž je reálný objekt mezi jednotlivými snímky ručně upravován a posouván o malé úseky, tak aby po spojení vyvolala animace dojem spojitosti. Jaký software lze pro stop motion použít na Linuxu? Článek na OMG! Ubuntu! představuje Heron Animation. Ten bohužel podporuje pouze webové kamery. Podpora digitálních zrcadlovek je začleněna například v programu qStopMotion.

Ladislav Hagara | Komentářů: 1
včera 21:21 | Nová verze Ladislav Hagara | Komentářů: 0
včera 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

Ladislav Hagara | Komentářů: 2
včera 00:10 | Nová verze

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

Ladislav Hagara | Komentářů: 4
6.12. 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 27
6.12. 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 2
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 50
5.12. 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 10
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 797 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: Část paměti processu v kernel space?

10.8.2008 05:27 Jiří J. | skóre: 34 | blog: Poutník | Brno
Část paměti processu v kernel space?
Přečteno: 366×
Zdravím,
snažím se pokud možno porozumět komunikaci mezi virtuálními adresovacími prostory, které Linux používá a narazil jsem na jeden problém.
Prošel jsem si pár tutoriálů pro tvorbu modulů, konkrétně mám na mysli LKMPG. Z něj jsem pochopil, že např. user process nemůže přistupovat do adresního prostoru kernelu, proto se při práci s /proc/xyz "soubory" kopírují data přes buffery z jednoho segmentu do druhého.

Na samotný "problém" jsem narazil zjištěním, že ono to jde nějak i bez daných funkcí - z kernelu mám normálně přístup do bufferu user aplikace přes pointer. Jako příklad může posloužit procfs3.c, konkrétně funkcí
/*
 * This function is called when /proc is written
 */
static ssize_t
procfs_write(struct file *file, const char *buffer, size_t len, loff_t * off)
{
	if ( len > PROCFS_MAX_SIZE )	{
		procfs_buffer_size = PROCFS_MAX_SIZE;
	}
	else	{
		procfs_buffer_size = len;
	}
	
	if ( copy_from_user(procfs_buffer, buffer, procfs_buffer_size) ) {
		return -EFAULT;
	}

	printk(KERN_INFO "procfs_write: write %lu bytes\n", procfs_buffer_size);
	
	return procfs_buffer_size;
}
- pokud na místo copy_from_user dám strncpy, vše (alespoň zdánlivě) funguje.
Při googlení jsem náhodou narazil i na http://mail.nl.linux.org/kernelnewbies/2005-01/msg00085.html, konkrétně
All kernel code runs in the kernel virtual memory address space. There are times, that the kernel virtual memory address space contains pieces of a user process's address space. This is so that system calls can access arguments passed using pointers. A classic example are the read() and write() system calls, which need to transfer data from kernel buffers into a user process address space.

Jak je to doopravdy? Kde se pes zakopal tak, že to funguje? :-D
Mám v modulech řešit kopírování do/z kernelspace přes copy_to_user/copy_from_user, resp. put_user/get_user i pokud jde o jednoduché read/write jako například s /proc filesystémem?

Díky za případné nápady/informace.
Víra je firma si myslela, že něco je pravdivé. LMAO -- “zlehčovat mého osla”

Odpovědi

Viliam Púčik avatar 10.8.2008 13:02 Viliam Púčik | skóre: 22 | blog: minimal
Rozbalit Rozbalit vše Re: Část paměti processu v kernel space?
Podla mna (berte prosim s rezervou):

Zalezi na tom, co sa kam kopiruje. Ked medzi User Space <-> Kernel Space, tak urcite copy_to_user/copy_from_user.

Vyssie uvedeny priklad s procfs_write kopiruje data z User Space do Kernel Space pomocou copy_to_user, takze potrebuje zistit, kam "skutocne" User Space pointer ukazuje. To, ze strncpy ako tak funguje, je len zhoda nahod.

Inak povedane, ak napriklad User Space pointer buffer ukazuje na User Space adresu 123h , tak funkcia copy_from_user hovori kernelu, aby pointer buffer nebral ako pointer na Kernel Space adresu 123h (ako by to bolo v pripade strncpy).
10.8.2008 13:39 Jiří J. | skóre: 34 | blog: Poutník | Brno
Rozbalit Rozbalit vše Re: Část paměti processu v kernel space?
Právě tak jsem to z informací z googlu pochopil, dva odlišné virtuální adresní prostory (každý 0x00000000 - 0xFFFFFFFF), kde mohou být data různě rozhozena, tzn. na adrese 0x00100000 mohou být data odlišná jak v userspace, tak v kernelspace.

Mě šlo spíše o to, jak je možné, že strncpy funguje.
Víra je firma si myslela, že něco je pravdivé. LMAO -- “zlehčovat mého osla”
10.8.2008 13:57 Jiří J. | skóre: 34 | blog: Poutník | Brno
Rozbalit Rozbalit vše Re: Část paměti processu v kernel space?
Tedy jak je možné, proč strncpy od userspace procesu funguje.
Dle LKMPG části o funkcích používajících procfs tento přenos není potřeba při "čtení" (z pohledu procesu), protože data jsou v bufferu v kernelspace (tedy read() z toho processu má přístup do bufferu v segmentu kernelu), ale při "zápisu" už se data musí přenášet.
Jenomže v mém případě to funguje i bez toho, možná, že se kernel v tomto ohledu zase posunul o něco dále a je možné provádět i write() do bufferu v kernelspace z userspace aplikace. Rád se dozvědel pravdu, pokud ji někdo zná.

Díky.
Víra je firma si myslela, že něco je pravdivé. LMAO -- “zlehčovat mého osla”
12.8.2008 10:19 Jirka P
Rozbalit Rozbalit vše Re: Část paměti processu v kernel space?
Nevím, jak moc je to s těmi segmenty pravda. Minimálně na x86 má kód běžící v kernel módu v kontextu procesu normálně přístup do paměti toho procesu, když se kouknete do zdrojáku copy_to/from_user, zjistíte, že je to prosté memcpy+ošetření chyb(+mmx optimalizace). To z principu neplatí se 4G/4G patchem, nelze přistupovat ke dvěma prostorům, každém o velikosti 4G, přímo. Nevím, jestli je to problém ještě jinde (třeba na 32b mipsu něco jako 4G/4G patch pokud vím nejde realizovat).

Kde ale určitě poznáte rozdíl mezi strcpy/copy_from_user, je co se stane když přístup na tu adresu segfaultne. strncpy oopsne, copy_from_user vrací chybu.
oroborus avatar 10.8.2008 16:51 oroborus | skóre: 20 | blog: Bulanci
Rozbalit Rozbalit vše Re: Část paměti processu v kernel space?
ja _nie_ _som_ expert a prepacte, ze vam do toho skacem, ale IMHO tie dva virtualne priestory na architekture i386 su :

user-space od 0 po 3GB virtualnej pamate
kernel-space od 3GB po 4GB virtualnej pamate

Takze nedochadza ku kolizii, medzi adresami z kernel-space a user-space. Tu ide o to, ze by sa mali pre zachovanie prenostitelnosti pouzivat funkcie copy_to_user/copy_from_user a put_user/get_user, ale na architekture x86 to ide aj bez nich, ale nemalo by sa to robit.
12.8.2008 04:27 luky
Rozbalit Rozbalit vše Re: Část paměti processu v kernel space?
Pristup do userspace reseny primym zpristupnenim celeho adresniho rozsahu kernelu je jen implementacni detail dane architektury, jinde ti to nepujde (a i tady ti to na neplatnych adresach hodi panic). Vzdy pouzivej copy funkce.

Založit nové vláknoNahoru

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.