Thread (138 messages) 138 messages, 8 authors, 2015-05-27

Re: [PATCH 4/8] fbdev: ssd1307fb: Use vmalloc to allocate video memory.

From: Maxime Ripard <hidden>
Date: 2015-02-14 15:40:10
Also in: lkml

On Sat, Feb 14, 2015 at 03:22:12PM +0100, Thomas Niederprüm wrote:
Am Thu, 12 Feb 2015 16:11:21 +0100
schrieb Maxime Ripard [off-list ref]:
quoted
On Sat, Feb 07, 2015 at 04:35:41PM +0100, Thomas Niederprüm wrote:
quoted
Am Sat, 7 Feb 2015 12:18:21 +0100
schrieb Maxime Ripard [off-list ref]:
quoted
Hi,

On Fri, Feb 06, 2015 at 11:28:10PM +0100, niederp@physik.uni-kl.de
wrote:
quoted
From: Thomas Niederprüm <redacted>

It makes sense to use vmalloc to allocate the video buffer
since it has to be page aligned memory for using it with mmap.
Please wrap your commit log at 80 chars.
I'll try to do so in future, sorry for that.
quoted
It looks like there's numerous fbdev drivers using this
(especially since you copy pasted that code, without mentionning
it).
Yes, I should have mentioned that in the commit message. As
implicitly indicated in the cover letter the rvmalloc() and
rvfree() are copy pasted from the vfb driver. Honestly, I didn't
give this one too much thought. It seemed a viable solution to the
mmap problem. For a bit more history on that, see my comment below.
quoted
That should be turned into an allocator so that drivers all get
this right.
quoted
Also deffered io seems buggy in combination with kmalloc'ed
memory (crash on unloading the module).
And maybe that's the real issue to fix.
The problem is solved by using vmalloc ;)
Yep, but why do you need to mark the reserved pages?

...
As far as I understood mmaped memory is marked as userspace memory in
the page table and is therefore subject to swapping. The pages are
marked reserved to make clear that this memory can not be swapped and
thus lock the pages in memory. See discussions [0,1,2]. 

[0]http://stackoverflow.com/questions/10760479/mmap-kernel-buffer-to-user-space
[1]http://www.linuxquestions.org/questions/linux-kernel-70/why-why-setpagereserved-is-needed-when-map-a-kernel-space-to-user-space-885176/
[2]https://sites.google.com/site/skartikeyan/mmap.html
Hmmm, both https://lwn.net/Articles/28746/ and
http://linux-mm.org/DeviceDriverMmap tell otherwise :)

Maxime

-- 
Maxime Ripard, Free Electrons
Embedded Linux, Kernel and Android engineering
http://free-electrons.com

Attachments

Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help