Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755740AbbGPPaX (ORCPT ); Thu, 16 Jul 2015 11:30:23 -0400 Received: from mailout2.w1.samsung.com ([210.118.77.12]:59417 "EHLO mailout2.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754222AbbGPPaS (ORCPT ); Thu, 16 Jul 2015 11:30:18 -0400 X-AuditID: cbfec7f4-f79c56d0000012ee-ca-55a7ce08033c Message-id: <55A7CE03.301@samsung.com> Date: Thu, 16 Jul 2015 18:30:11 +0300 From: Andrey Ryabinin User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.7.0 MIME-version: 1.0 To: Catalin Marinas Cc: Arnd Bergmann , linux-mm@kvack.org, Will Deacon , linux-kernel@vger.kernel.org, David Keitel , Alexander Potapenko , linux-arm-kernel@lists.infradead.org, Andrew Morton , Dmitry Vyukov Subject: Re: [PATCH v2 5/5] arm64: add KASan support References: <1431698344-28054-1-git-send-email-a.ryabinin@samsung.com> <1431698344-28054-6-git-send-email-a.ryabinin@samsung.com> <20150708154803.GE6944@e104818-lin.cambridge.arm.com> <559FFCA7.4060008@samsung.com> <20150714150445.GH13555@e104818-lin.cambridge.arm.com> <55A61FF8.9000603@samsung.com> <20150715163732.GF20186@e104818-lin.cambridge.arm.com> In-reply-to: <20150715163732.GF20186@e104818-lin.cambridge.arm.com> Content-type: text/plain; charset=windows-1252 Content-transfer-encoding: 7bit X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFvrOLMWRmVeSWpSXmKPExsVy+t/xa7oc55aHGvxr5raYs34Nm8XfScfY Ld4v62G02H3pGbPFhIdt7BbtH/cyW2x6fI3V4vKuOWwW99b8Z7V4+fEEiwOXx5p5axg9fv+a xOhxua+XyWPBplKPTZ8msXucmPGbxWPzknqPz5vkAjiiuGxSUnMyy1KL9O0SuDK2/G9lKlgt UdF4cjNTA+Me4S5GTg4JAROJr2d2sEHYYhIX7q0Hs4UEljJK3H5Z3sXIBWR/Z5Q4vvIKI0iC V0BNYvrlI2A2i4CqxNKv/1hAbDYBPYl/s7aDNYsKREi8vXySCaJeUOLH5HtgNSICuhIX2qaw gAxlFjjMJLFqah/YIGGgK54sX8IOse09k8Tbr41gHZwCzhLLOg4CJTiAOvQk7l/UAgkzC8hL bF7zlnkCo8AsJDtmIVTNQlK1gJF5FaNoamlyQXFSeq6hXnFibnFpXrpecn7uJkZIdHzZwbj4 mNUhRgEORiUeXo7fy0KFWBPLiitzDzFKcDArifDKbVseKsSbklhZlVqUH19UmpNafIhRmoNF SZx37q73IUIC6YklqdmpqQWpRTBZJg5OqQZGvl/XLsQ16b4x0JlfKet6v4j3p8UGVmtdtfsr +Gy2bWLgZDbI7Fph5N36td0mpVfuW+H+3Uwz2sP+dJQFpQQdV7lwxMGl7Wy7Rh7frRzbjuZ3 9ibN105485dbG6T90Hif2aXmMU12IfOez5073uUckV+8lXG3/knXK7fW1/prMclyeRc9/KzE UpyRaKjFXFScCAB7SVp8igIAAA== Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3252 Lines: 113 On 07/15/2015 07:37 PM, Catalin Marinas wrote: > Ok, so simply taking the call out of the loop won't work unless we > conditionally define these functions (wouldn't be too bad since we have > some #if CONFIG_PGTABLE_LEVELS already introduced by this patch but it > would be nicer without). > > Anyway, I think we can keep the current iterations but exit early if > !pud_none() because it means we already populated it (reworked to match > other such patterns throughout the kernel with pgd_populate called from > the pud function; and untested): > > void kasan_early_pmd_populate(pud_t *pud, unsigned long addr, unsigned long end) > { > pmd_t *pmd; > unsigned long next; > > if (pud_none(*pud)) > pud_populate(&init_mm, pud, kasan_zero_pmd); > > pmd = pmd_offset(pud, addr); > do { > next = pmd_addr_end(addr, end); > kasan_early_pte_populate(pmd, addr, next); > } while (pmd++, addr = next, addr != end && pmd_none(*pmd)); > } > > void kasan_early_pud_populate(pgd_t *pgd, unsigned long addr, unsigned long end) > { > pud_t *pud; > unsigned long next; > > if (pgd_none(*pgd)) > pgd_populate(&init_mm, pgd, kasan_zero_pud); > > pud = pud_offset(pgd, addr); > do { > next = pud_addr_end(addr, end); > kasan_early_pmd_populate(pud, addr, next); > } while (pud++, addr = next, addr != end && pud_none(*pud)); > } > > Given that we check pud_none() after the first iterations, it covers the > lower levels if needed. > I think this may work, if pud_none(*pud) will be replaced with !pud_val(*pud). We can't use pud_none() because with 2-level page tables it's always false, so we will never go down to pmd level where swapper_pg_dir populated. But you gave me another idea how we could use p?d_none() and avoid rewriting table entries: void kasan_early_pmd_populate(unsigned long start, unsigned long end, pte_t *pte) { unsigned long addr = start; long next; do { pgd_t *pgd = pgd_offset_k(addr); pud_t *pud = pud_offset(pgd, addr); pmd_t *pmd = pmd_offset(pud, addr); if (!pmd_none(*pmd)) break; pmd_populate_kernel(&init_mm, pmd, pte); next = pgd_addr_end(addr, end); next = pud_addr_end(addr, next) next = pmd_addr_end(addr, next); } while(addr = next, addr != end); } void kasan_early_pud_populate(unsigned long start, unsigned long end, pmd_t *pmd) { unsigned long addr = start; long next; do { pgd_t *pgd = pgd_offset_k(addr); pud_t *pud = pud_offset(pgd, addr); if (!pud_none(*pud)) break; pud_populate(&init_mm, pud, pmd); next = pud_addr_end(addr, pgd_addr_end(addr, end)); } while(addr = next, addr != end); } void kasan_early_pgd_populate(...) { //something similar to above .... } static void __init kasan_map_early_shadow(void) { kasan_early_pgd_populate(KASAN_SHADOW_START, KASAN_SHADOW_END, kasan_zero_pud); kasan_early_pud_populate(KASAN_SHADOW_START, KASAN_SHADOW_END, kasan_zero_pmd); kasan_early_pmd_populate(KASAN_SHADOW_START, KASAN_SHADOW_END, kasan_zero_pte); kasan_early_pte_populate(); } -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/