[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-id: <008b01cbf362$6fb52c40$4f1f84c0$%szyprowski@samsung.com>
Date: Tue, 05 Apr 2011 09:23:53 +0200
From: Marek Szyprowski <m.szyprowski@...sung.com>
To: 'Michal Nazarewicz' <mina86@...a86.com>,
'Dave Hansen' <dave@...ux.vnet.ibm.com>
Cc: linux-kernel@...r.kernel.org, linux-arm-kernel@...ts.infradead.org,
linux-samsung-soc@...r.kernel.org, linux-media@...r.kernel.org,
linux-mm@...ck.org, 'Kyungmin Park' <kyungmin.park@...sung.com>,
'Andrew Morton' <akpm@...ux-foundation.org>,
'KAMEZAWA Hiroyuki' <kamezawa.hiroyu@...fujitsu.com>,
'Ankita Garg' <ankita@...ibm.com>,
'Daniel Walker' <dwalker@...eaurora.org>,
'Johan MOSSBERG' <johan.xx.mossberg@...ricsson.com>,
'Mel Gorman' <mel@....ul.ie>,
'Pawel Osciak' <pawel@...iak.com>,
'Marek Szyprowski' <m.szyprowski@...sung.com>
Subject: RE: [PATCH 04/12] mm: alloc_contig_freed_pages() added
Hello,
On Monday, April 04, 2011 3:15 PM MichaĆ Nazarewicz wrote:
> > What kind of success have you had running this in practice? I'd be
> > worried that some silly task or a sticky dentry would end up in the
> > range that you want to allocate in.
>
> I'm not sure what you are asking.
>
> The function requires the range to be marked as MIGRATE_ISOLATE and all
> pages being free, so nothing can be allocated there while the function
> is running.
>
> If you are asking about CMA in general, the range that CMA uses is marked
> as MIGRATE_CMA (a new migrate type) which means that only MIGRATE_MOVABLE
> pages can be allocated there. This means, that in theory, if there is
> enough memory the pages can always be moved out of the region. At leasts
> that's my understanding of the type. If this is correct, the allocation
> should always succeed provided enough memory for the pages within the
> region to be moved to is available.
>
> As of practice, I have run some simple test to see if the code works and
> they succeeded. Also, Marek has run some test with actual hardware and
> those worked well as well (but I'll let Marek talk about any details).
We did the tests with real multimedia drivers - video codec and video
converter (s5p-mfc and s5p-fimc). These drivers allocate large contiguous
buffers for video data. The allocation is performed when driver is opened
by user space application.
First we consumed system memory by running a set of simple applications
that just did some malloc() and filled memory with random pattern to consume
free pages. Then some of that memory has been freed and we ran the video
decoding application. Multimedia drivers successfully managed to allocate
required contiguous buffers from MIGRATE_CMA ranges.
The tests have been performed with different system usage patterns (malloc(),
heavy filesystem load, anonymous memory mapping). In all these cases CMA
worked surprisingly good allowing the drivers to allocate the required
contiguous buffers.
Best regards
--
Marek Szyprowski
Samsung Poland R&D Center
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists