4 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 only,
8 * as published by the Free Software Foundation.
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License version 2 for more details (a copy is included
14 * in the LICENSE file that accompanied this code).
16 * You should have received a copy of the GNU General Public License
17 * version 2 along with this program; if not, write to the
18 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
19 * Boston, MA 021110-1307, USA
24 * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
25 * Copyright (c) 2012, 2013, Intel Corporation.
28 * This file is part of Lustre, http://www.lustre.org/
29 * Lustre is a trademark of Sun Microsystems, Inc.
31 * Please see comments in libcfs/include/libcfs/libcfs_cpu.h for introduction
33 * Author: liang@whamcloud.com
36 #define DEBUG_SUBSYSTEM S_LNET
38 #include <libcfs/libcfs.h>
40 /** Global CPU partition table */
41 struct cfs_cpt_table *cfs_cpt_table __read_mostly = NULL;
42 EXPORT_SYMBOL(cfs_cpt_table);
44 #ifndef HAVE_LIBCFS_CPT
46 #define CFS_CPU_VERSION_MAGIC 0xbabecafe
48 #define CFS_CPT_DISTANCE 1 /* Arbitrary positive value */
50 struct cfs_cpt_table *
51 cfs_cpt_table_alloc(unsigned int ncpt)
53 struct cfs_cpt_table *cptab;
56 CERROR("Can't support cpu partition number %d\n", ncpt);
60 LIBCFS_ALLOC(cptab, sizeof(*cptab));
62 cptab->ctb_version = CFS_CPU_VERSION_MAGIC;
63 cpu_set(0, cptab->ctb_cpumask);
64 node_set(0, cptab->ctb_nodemask);
65 cptab->ctb_nparts = ncpt;
70 EXPORT_SYMBOL(cfs_cpt_table_alloc);
73 cfs_cpt_table_free(struct cfs_cpt_table *cptab)
75 LASSERT(cptab->ctb_version == CFS_CPU_VERSION_MAGIC);
77 LIBCFS_FREE(cptab, sizeof(*cptab));
79 EXPORT_SYMBOL(cfs_cpt_table_free);
82 cfs_cpt_table_print(struct cfs_cpt_table *cptab, char *buf, int len)
86 rc = snprintf(buf, len, "%d\t: %d\n", 0, 0);
93 EXPORT_SYMBOL(cfs_cpt_table_print);
96 cfs_cpt_distance_print(struct cfs_cpt_table *cptab, char *buf, int len)
100 rc = snprintf(buf, len, "%d\t: %d:%d\n", 0, CFS_CPT_DISTANCE);
107 EXPORT_SYMBOL(cfs_cpt_distance_print);
110 cfs_cpt_number(struct cfs_cpt_table *cptab)
114 EXPORT_SYMBOL(cfs_cpt_number);
117 cfs_cpt_weight(struct cfs_cpt_table *cptab, int cpt)
121 EXPORT_SYMBOL(cfs_cpt_weight);
124 cfs_cpt_online(struct cfs_cpt_table *cptab, int cpt)
128 EXPORT_SYMBOL(cfs_cpt_online);
131 cfs_cpt_cpumask(struct cfs_cpt_table *cptab, int cpt)
133 return &cptab->ctb_mask;
135 EXPORT_SYMBOL(cfs_cpt_cpumask);
138 cfs_cpt_nodemask(struct cfs_cpt_table *cptab, int cpt)
140 return &cptab->ctb_nodemask;
142 EXPORT_SYMBOL(cfs_cpt_nodemask);
145 cfs_cpt_distance(struct cfs_cpt_table *cptab, int cpt1, int cpt2)
147 return CFS_CPT_DISTANCE;
149 EXPORT_SYMBOL(cfs_cpt_distance);
152 cfs_cpt_set_cpu(struct cfs_cpt_table *cptab, int cpt, int cpu)
156 EXPORT_SYMBOL(cfs_cpt_set_cpu);
159 cfs_cpt_unset_cpu(struct cfs_cpt_table *cptab, int cpt, int cpu)
162 EXPORT_SYMBOL(cfs_cpt_unset_cpu);
165 cfs_cpt_set_cpumask(struct cfs_cpt_table *cptab, int cpt, const cpumask_t *mask)
169 EXPORT_SYMBOL(cfs_cpt_set_cpumask);
172 cfs_cpt_unset_cpumask(struct cfs_cpt_table *cptab, int cpt,
173 const cpumask_t *mask)
176 EXPORT_SYMBOL(cfs_cpt_unset_cpumask);
179 cfs_cpt_set_node(struct cfs_cpt_table *cptab, int cpt, int node)
183 EXPORT_SYMBOL(cfs_cpt_set_node);
186 cfs_cpt_unset_node(struct cfs_cpt_table *cptab, int cpt, int node)
189 EXPORT_SYMBOL(cfs_cpt_unset_node);
192 cfs_cpt_set_nodemask(struct cfs_cpt_table *cptab, int cpt, nodemask_t *mask)
196 EXPORT_SYMBOL(cfs_cpt_set_nodemask);
199 cfs_cpt_unset_nodemask(struct cfs_cpt_table *cptab, int cpt, nodemask_t *mask)
202 EXPORT_SYMBOL(cfs_cpt_unset_nodemask);
205 cfs_cpt_spread_node(struct cfs_cpt_table *cptab, int cpt)
209 EXPORT_SYMBOL(cfs_cpt_spread_node);
212 cfs_cpt_current(struct cfs_cpt_table *cptab, int remap)
216 EXPORT_SYMBOL(cfs_cpt_current);
219 cfs_cpt_of_cpu(struct cfs_cpt_table *cptab, int cpu)
223 EXPORT_SYMBOL(cfs_cpt_of_cpu);
226 cfs_cpt_of_node(struct cfs_cpt_table *cptab, int node)
230 EXPORT_SYMBOL(cfs_cpt_of_node);
233 cfs_cpt_bind(struct cfs_cpt_table *cptab, int cpt)
237 EXPORT_SYMBOL(cfs_cpt_bind);
242 if (cfs_cpt_table != NULL) {
243 cfs_cpt_table_free(cfs_cpt_table);
244 cfs_cpt_table = NULL;
251 cfs_cpt_table = cfs_cpt_table_alloc(1);
253 return cfs_cpt_table != NULL ? 0 : -1;
256 #endif /* HAVE_LIBCFS_CPT */