Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp3136566ybz; Sun, 3 May 2020 18:15:05 -0700 (PDT) X-Google-Smtp-Source: APiQypIj0B+NDDEwOanFfG+rQCRAcjS+qmQspRbAl4+JZjGve9CefC6OcBpjHKZo+Qj9YHoOJR5D X-Received: by 2002:a50:eacb:: with SMTP id u11mr12456047edp.162.1588554905139; Sun, 03 May 2020 18:15:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588554905; cv=none; d=google.com; s=arc-20160816; b=PPWDG9pPDdAYjJwiNYzJGq+v6d/drOFgaajtVCpG9a9PmeyUM7CrZb19CEvVPf1XC3 ZoBSJJo1CURM7lhokIf+8ph9SbO4VhFEZM/RQQ1QQLxtt32QfXESJbCVQGW29H2V2Vkx kv3dSYxo177ANVVOsg7uz3li+2xpsvhVApDmfSVkBjZL3OsSTRMEbpqHW1Q4rwCTNFZO i5WkwCN9bjpUFjlGIU3AR62p6aNdHd6O1MUqSF2jLGKV0YoVqpYtMP+Zc71csPt3URQF Vhe2uFpT1QRfnh9ZwXVMAkSjr1Zx4rYP8OvfdDxTlGt9cs08jdKZZXOvDzRnF61Ppf2J o+cQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:ironport-sdr:ironport-sdr; bh=5+wUutKc3K6FJ/Lbsu4oFxorq4EYoVV1HaX0LkONE9I=; b=kXU49mE4/a/BE14F6KfghWlt5oZtI0ImuwOLNj5A/rc6nJrVCzgeF5nqRRIMS+mNEQ F1iqghFeQw5qd4PoHLhKRcre+ioq8qY2BMMbB4gc86iruvCXV2LMaaA/3dWkw84wCXFH LOs7tSgG4hyJ6yz/BOqE52NyWTVmzd/PIuaVW9ZyDsSC1Y5vvnpzOpfG5zEZv14fLO25 frnElHHslAPCZb9zlQzkLyr/kpPo1s0NNpjvdMr/Fp+VIdrEVAF/wSKDC/ZwfAFlL8W9 xCU0Tv9YQAE3v00F2rqdZZHjS4ALPD1NAlPTxBiqZOuWICh7nRG7AGmDMv/FWHEO/ndl EdjQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f8si6514718ejt.461.2020.05.03.18.14.42; Sun, 03 May 2020 18:15:05 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727119AbgEDBJY (ORCPT + 99 others); Sun, 3 May 2020 21:09:24 -0400 Received: from mga11.intel.com ([192.55.52.93]:17935 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726282AbgEDBJW (ORCPT ); Sun, 3 May 2020 21:09:22 -0400 IronPort-SDR: A9YDjvCFSAVRZt9PK6T6bah1ORcFaay/xLXeYJlc6YM+kvTo9s31EfXuPQPfGhntjjL6mPEk1b znGgE4vjXnFQ== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga007.jf.intel.com ([10.7.209.58]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 03 May 2020 18:09:20 -0700 IronPort-SDR: fHucA4RWhttBOWYdNcVbZcLe92djrCMA36BhMr8sTNTq9uR1pF6GcVTIexdnyZrcSkJFrWzqIJ LnPtCLKlHAVA== X-IronPort-AV: E=Sophos;i="5.73,350,1583222400"; d="scan'208";a="248071661" Received: from iweiny-desk2.sc.intel.com (HELO localhost) ([10.3.52.147]) by orsmga007-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 03 May 2020 18:09:19 -0700 From: ira.weiny@intel.com To: linux-kernel@vger.kernel.org, Andrew Morton , Christian Koenig , Huang Rui Cc: Ira Weiny , Thomas Bogendoerfer , "James E.J. Bottomley" , Helge Deller , Benjamin Herrenschmidt , Paul Mackerras , "David S. Miller" , Thomas Gleixner , Ingo Molnar , Borislav Petkov , x86@kernel.org, "H. Peter Anvin" , Dave Hansen , Andy Lutomirski , Peter Zijlstra , Chris Zankel , Max Filippov , Dan Williams , linux-snps-arc@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-csky@vger.kernel.org, linux-mips@vger.kernel.org, linux-parisc@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, sparclinux@vger.kernel.org, linux-xtensa@linux-xtensa.org, dri-devel@lists.freedesktop.org Subject: [PATCH V2 00/11] Subject: Remove duplicated kmap code Date: Sun, 3 May 2020 18:09:01 -0700 Message-Id: <20200504010912.982044-1-ira.weiny@intel.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Ira Weiny The kmap infrastructure has been copied almost verbatim to every architecture. This series consolidates obvious duplicated code by defining core functions which call into the architectures only when needed. Some of the k[un]map_atomic() implementations have some similarities but the similarities were not sufficient to warrant further changes. In addition we remove a duplicate implementation of kmap() in DRM. Testing was done by 0day to cover all the architectures I can't readily build/test. --- Changes from V1: Fix bisect-ability Update commit message and fix line lengths Remove unneded kunmap_atomic_high() declarations Remove unneded kmap_atomic_high() declarations collect reviews rebase to 5.7-rc4 Changes from V0: Define kmap_flush_tlb() and make kmap() truely arch independent. Redefine the k[un]map_atomic_* code to call into the architectures for high mem pages Ensure all architectures define kmap_prot, use it appropriately, and define kmap_atomic_prot() Remove drm implementation of kmap_atomic() Ira Weiny (11): arch/kmap: Remove BUG_ON() arch/xtensa: Move kmap build bug out of the way arch/kmap: Remove redundant arch specific kmaps arch/kunmap: Remove duplicate kunmap implementations {x86,powerpc,microblaze}/kmap: Move preempt disable arch/kmap_atomic: Consolidate duplicate code arch/kunmap_atomic: Consolidate duplicate code arch/kmap: Ensure kmap_prot visibility arch/kmap: Don't hard code kmap_prot values arch/kmap: Define kmap_atomic_prot() for all arch's drm: Remove drm specific kmap_atomic code arch/arc/include/asm/highmem.h | 15 ------- arch/arc/mm/highmem.c | 28 +++--------- arch/arm/include/asm/highmem.h | 7 --- arch/arm/mm/highmem.c | 35 +++------------ arch/csky/include/asm/highmem.h | 9 +--- arch/csky/mm/highmem.c | 43 +++++-------------- arch/microblaze/include/asm/highmem.h | 28 +----------- arch/microblaze/mm/highmem.c | 16 ++----- arch/microblaze/mm/init.c | 3 -- arch/mips/include/asm/highmem.h | 9 +--- arch/mips/mm/cache.c | 6 +-- arch/mips/mm/highmem.c | 49 ++++----------------- arch/nds32/include/asm/highmem.h | 7 --- arch/nds32/mm/highmem.c | 39 +++-------------- arch/parisc/include/asm/cacheflush.h | 4 +- arch/powerpc/include/asm/highmem.h | 29 +------------ arch/powerpc/mm/highmem.c | 21 ++------- arch/powerpc/mm/mem.c | 3 -- arch/sparc/include/asm/highmem.h | 22 ---------- arch/sparc/mm/highmem.c | 18 +++----- arch/x86/include/asm/highmem.h | 9 ---- arch/x86/mm/highmem_32.c | 50 ++------------------- arch/xtensa/include/asm/highmem.h | 27 ------------ arch/xtensa/mm/highmem.c | 22 ++++------ drivers/gpu/drm/ttm/ttm_bo_util.c | 56 ++---------------------- drivers/gpu/drm/vmwgfx/vmwgfx_blit.c | 16 +++---- include/drm/ttm/ttm_bo_api.h | 4 -- include/linux/highmem.h | 62 +++++++++++++++++++++++++-- 28 files changed, 140 insertions(+), 497 deletions(-) -- 2.25.1