On Thu, 27 Mar 2008, Linus Torvalds wrote:prep_zero_page does: static inline void prep_zero_page(struct page *page, int order, gfp_t gfp_flags) { int i; /* * clear_highpage() will use KM_USER0, so it's a bug to use __GFP_ZERO * and __GFP_HIGHMEM from hard or soft interrupt context. */ VM_BUG_ON((gfp_flags & __GFP_HIGHMEM) && in_interrupt()); for (i = 0; i < (1 << order); i++) clear_highpage(page + i); } So we forbit __GFP_HIGHMEM and in_interrupt which makes sense. The simple forwarding of large kmallocs to the page allocator as done by SLUB / SLOB is fine. Then clear_highpage calls additional checking functions that have the effect of generally forbiding zeroing in interrupt context if CONFIG_HIGHMEM is set. This is wrong and needs to be fixed. Well that is only the fallback path of __slab_alloc which is not triggered here and not performance sensitive. We could clear the flag there but that is irrevelant for this issue. --
| Ingo Molnar | [patch 02/13] syslets: add syslet.h include file, user API/ABI definitions |
| Heiko Carstens | Re: 2.6.25-rc6-git6: Reported regressions from 2.6.24 |
| Greg Kroah-Hartman | [PATCH 010/196] Chinese: add translation of Codingstyle |
| Rafael J. Wysocki | [Bug #10629] 2.6.26-rc1-$sha1: RIP __d_lookup+0x8c/0x160 |
git: | |
| Gerrit Renker | [PATCH 0/37] dccp: Feature negotiation - last call for comments |
| Linus Torvalds | Re: [GIT]: Networking |
| Mark Lord | Re: [BUG] New Kernel Bugs |
| Jarek Poplawski | [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock(). |
