~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/mm/numa.c

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /mm/numa.c (Architecture sparc) and /mm/numa.c (Architecture i386)


  1 // SPDX-License-Identifier: GPL-2.0-or-later        1 // SPDX-License-Identifier: GPL-2.0-or-later
  2                                                     2 
  3 #include <linux/memblock.h>                         3 #include <linux/memblock.h>
  4 #include <linux/printk.h>                           4 #include <linux/printk.h>
  5 #include <linux/numa.h>                             5 #include <linux/numa.h>
  6 #include <linux/numa_memblks.h>                     6 #include <linux/numa_memblks.h>
  7                                                     7 
  8 struct pglist_data *node_data[MAX_NUMNODES];        8 struct pglist_data *node_data[MAX_NUMNODES];
  9 EXPORT_SYMBOL(node_data);                           9 EXPORT_SYMBOL(node_data);
 10                                                    10 
 11 /* Allocate NODE_DATA for a node on the local      11 /* Allocate NODE_DATA for a node on the local memory */
 12 void __init alloc_node_data(int nid)               12 void __init alloc_node_data(int nid)
 13 {                                                  13 {
 14         const size_t nd_size = roundup(sizeof(     14         const size_t nd_size = roundup(sizeof(pg_data_t), SMP_CACHE_BYTES);
 15         u64 nd_pa;                                 15         u64 nd_pa;
 16         void *nd;                                  16         void *nd;
 17         int tnid;                                  17         int tnid;
 18                                                    18 
 19         /* Allocate node data.  Try node-local     19         /* Allocate node data.  Try node-local memory and then any node. */
 20         nd_pa = memblock_phys_alloc_try_nid(nd     20         nd_pa = memblock_phys_alloc_try_nid(nd_size, SMP_CACHE_BYTES, nid);
 21         if (!nd_pa)                                21         if (!nd_pa)
 22                 panic("Cannot allocate %zu byt     22                 panic("Cannot allocate %zu bytes for node %d data\n",
 23                       nd_size, nid);               23                       nd_size, nid);
 24         nd = __va(nd_pa);                          24         nd = __va(nd_pa);
 25                                                    25 
 26         /* report and initialize */                26         /* report and initialize */
 27         pr_info("NODE_DATA(%d) allocated [mem      27         pr_info("NODE_DATA(%d) allocated [mem %#010Lx-%#010Lx]\n", nid,
 28                 nd_pa, nd_pa + nd_size - 1);       28                 nd_pa, nd_pa + nd_size - 1);
 29         tnid = early_pfn_to_nid(nd_pa >> PAGE_     29         tnid = early_pfn_to_nid(nd_pa >> PAGE_SHIFT);
 30         if (tnid != nid)                           30         if (tnid != nid)
 31                 pr_info("    NODE_DATA(%d) on      31                 pr_info("    NODE_DATA(%d) on node %d\n", nid, tnid);
 32                                                    32 
 33         node_data[nid] = nd;                       33         node_data[nid] = nd;
 34         memset(NODE_DATA(nid), 0, sizeof(pg_da     34         memset(NODE_DATA(nid), 0, sizeof(pg_data_t));
 35 }                                                  35 }
 36                                                    36 
 37 void __init alloc_offline_node_data(int nid)       37 void __init alloc_offline_node_data(int nid)
 38 {                                                  38 {
 39         pg_data_t *pgdat;                          39         pg_data_t *pgdat;
 40                                                    40 
 41         pgdat = memblock_alloc(sizeof(*pgdat),     41         pgdat = memblock_alloc(sizeof(*pgdat), SMP_CACHE_BYTES);
 42         if (!pgdat)                                42         if (!pgdat)
 43                 panic("Cannot allocate %zuB fo     43                 panic("Cannot allocate %zuB for node %d.\n",
 44                       sizeof(*pgdat), nid);        44                       sizeof(*pgdat), nid);
 45                                                    45 
 46         node_data[nid] = pgdat;                    46         node_data[nid] = pgdat;
 47 }                                                  47 }
 48                                                    48 
 49 /* Stub functions: */                              49 /* Stub functions: */
 50                                                    50 
 51 #ifndef memory_add_physaddr_to_nid                 51 #ifndef memory_add_physaddr_to_nid
 52 int memory_add_physaddr_to_nid(u64 start)          52 int memory_add_physaddr_to_nid(u64 start)
 53 {                                                  53 {
 54         pr_info_once("Unknown online node for      54         pr_info_once("Unknown online node for memory at 0x%llx, assuming node 0\n",
 55                         start);                    55                         start);
 56         return 0;                                  56         return 0;
 57 }                                                  57 }
 58 EXPORT_SYMBOL_GPL(memory_add_physaddr_to_nid);     58 EXPORT_SYMBOL_GPL(memory_add_physaddr_to_nid);
 59 #endif                                             59 #endif
 60                                                    60 
 61 #ifndef phys_to_target_node                        61 #ifndef phys_to_target_node
 62 int phys_to_target_node(u64 start)                 62 int phys_to_target_node(u64 start)
 63 {                                                  63 {
 64         pr_info_once("Unknown target node for      64         pr_info_once("Unknown target node for memory at 0x%llx, assuming node 0\n",
 65                         start);                    65                         start);
 66         return 0;                                  66         return 0;
 67 }                                                  67 }
 68 EXPORT_SYMBOL_GPL(phys_to_target_node);            68 EXPORT_SYMBOL_GPL(phys_to_target_node);
 69 #endif                                             69 #endif
 70                                                    70 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php