Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753180AbcCBW4T (ORCPT ); Wed, 2 Mar 2016 17:56:19 -0500 Received: from mail-pf0-f196.google.com ([209.85.192.196]:34363 "EHLO mail-pf0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750963AbcCBW4Q (ORCPT ); Wed, 2 Mar 2016 17:56:16 -0500 From: David Daney To: Will Deacon , linux-arm-kernel@lists.infradead.org, Rob Herring , Frank Rowand , Grant Likely , Pawel Moll , Ian Campbell , Kumar Gala , Ganapatrao Kulkarni , Robert Richter , Ard Biesheuvel , Matt Fleming , Mark Rutland , Catalin Marinas Cc: linux-efi@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, David Daney Subject: [PATCH v13 0/6] arm64, numa: Add numa support for arm64 platforms Date: Wed, 2 Mar 2016 14:55:56 -0800 Message-Id: <1456959362-2036-1-git-send-email-ddaney.cavm@gmail.com> X-Mailer: git-send-email 1.7.11.7 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4640 Lines: 130 From: David Daney v13: - Added patch to unflatten the device tree earlier. - Rewrote of_numa.c to work on unflattened the device tree. - Cleanup of EXPORTs in arch/arm64/mm/numa.c as suggested by Will Deacon. v12: - Replaced 6 patches from Ard Biesheuvel with new simpler, and more correct, single patch, also from Ard. v11: - Dropped cleanup patches for other architectures, they will be submitted as a separate set after more testing. - Added patch set from Ard Biesheuvel that are needed to make the whole thing actually work. Previously this was a separate set. - Kconfig and other fixes and simplifications as suggested by Rob Herring. - Rearranged, refactored and reordered so that we don't patch new files multiple times. - Summary: o 6 patches from Ard Biesheuvel to allow use of "memory" nodes with efi stub. o 2 patches to document and add of_numa.c o 1 patch to add arm64 NUMA support. o 1 patch to add NUMA balancing support for arm64. v10: - Incorporated review comments from Rob Herring. - Moved numa binding and implementation to devicetree core. - Added cleanup patch to remove redundant NODE_DATA macro from asm header files - Include numa balancing support for arm64 patch in this series. - Fix tile build issue reported by the kbuild robot(patch 7) v9: - Added cleanup patch to reuse and avoid redefinition of cpumask_of_pcibus as suggested from Will Deacon and Bjorn Helgaas. - Including patch to Make pci-host-generic driver numa aware. - Incorporated comment from Shannon Zhao. v8: - Incorporated review comments of Mark Rutland and Will Deacon. - Added pci helper function and macro for numa. v7: - managing numa memory mapping using memblock. - Incorporated review comments of Mark Rutland. v6: - defined and implemented the numa dt binding using node property proximity and device node distance-map. - renamed dt_numa to of_numa v5: - created base verion of numa.c which creates dummy numa without using dt on single socket platforms. Then added patches for dt support. - Incorporated review comments from Hanjun Guo. v4: done changes as per Arnd review comments. v3: Added changes to support numa on arm64 based platforms. Tested these patches on cavium's multinode(2 node topology) platform. In this patchset, defined and implemented dt bindings for numa mapping for core and memory using device node property arm,associativity. v2: Defined and implemented numa map for memory, cores to node and proximity distance matrix of nodes. v1: Initial patchset to support numa on arm64 platforms. Note: 1. This patchset is tested for NUMA and without NUMA with dt (both with and without NUMA bindings) on thunderx single socket and dual socket boards. Ard Biesheuvel (1): efi: ARM/arm64: ignore DT memory nodes instead of removing them David Daney (2): of, numa: Add NUMA of binding implementation. arm64: Move unflatten_device_tree() call earlier. Ganapatrao Kulkarni (3): Documentation, dt, numa: dt bindings for NUMA. arm64, numa: Add NUMA support for arm64 platforms. arm64, mm, numa: Add NUMA balancing support for arm64. Documentation/devicetree/bindings/numa.txt | 272 ++++++++++++++++++++ arch/arm64/Kconfig | 27 ++ arch/arm64/include/asm/mmzone.h | 12 + arch/arm64/include/asm/numa.h | 45 ++++ arch/arm64/include/asm/pgtable.h | 15 ++ arch/arm64/include/asm/topology.h | 10 + arch/arm64/kernel/pci.c | 10 + arch/arm64/kernel/setup.c | 11 +- arch/arm64/kernel/smp.c | 4 + arch/arm64/mm/Makefile | 1 + arch/arm64/mm/init.c | 34 ++- arch/arm64/mm/mmu.c | 6 + arch/arm64/mm/numa.c | 396 +++++++++++++++++++++++++++++ drivers/firmware/efi/arm-init.c | 8 + drivers/firmware/efi/libstub/fdt.c | 24 +- drivers/of/Kconfig | 3 + drivers/of/Makefile | 1 + drivers/of/of_numa.c | 200 +++++++++++++++ include/linux/of.h | 9 + 19 files changed, 1056 insertions(+), 32 deletions(-) create mode 100644 Documentation/devicetree/bindings/numa.txt create mode 100644 arch/arm64/include/asm/mmzone.h create mode 100644 arch/arm64/include/asm/numa.h create mode 100644 arch/arm64/mm/numa.c create mode 100644 drivers/of/of_numa.c -- 1.8.3.1