Commit 3867ea5a authored by Peng Tao's avatar Peng Tao Committed by Greg Kroah-Hartman
Browse files

staging/lustre: fix build error when !CONFIG_SMP



Three functions cfs_cpu_ht_nsiblings, cfs_cpt_cpumask and
cfs_cpt_table_print are missing if !CONFIG_SMP.

cpumask_t/nodemask_t/__read_mostly/____cacheline_aligned
are redefined.

Signed-off-by: default avatarPeng Tao <tao.peng@emc.com>
Signed-off-by: default avatarAndreas Dilger <andreas.dilger@intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 5e8f6920
Loading
Loading
Loading
Loading
+23 −23
Original line number Diff line number Diff line
@@ -75,11 +75,19 @@
#ifndef __LIBCFS_CPU_H__
#define __LIBCFS_CPU_H__

#ifndef HAVE_LIBCFS_CPT

typedef unsigned long		cpumask_t;
typedef unsigned long		nodemask_t;
/* any CPU partition */
#define CFS_CPT_ANY		(-1)

#ifdef CONFIG_SMP
/**
 * return cpumask of CPU partition \a cpt
 */
cpumask_t *cfs_cpt_cpumask(struct cfs_cpt_table *cptab, int cpt);
/**
 * print string information of cpt-table
 */
int cfs_cpt_table_print(struct cfs_cpt_table *cptab, char *buf, int len);
#else /* !CONFIG_SMP */
struct cfs_cpt_table {
	/* # of CPU partitions */
	int			ctb_nparts;
@@ -91,10 +99,18 @@ struct cfs_cpt_table {
	__u64			ctb_version;
};

#endif /* !HAVE_LIBCFS_CPT */
static inline cpumask_t *
cfs_cpt_cpumask(struct cfs_cpt_table *cptab, int cpt)
{
       return NULL;
}

/* any CPU partition */
#define CFS_CPT_ANY		(-1)
static inline int
cfs_cpt_table_print(struct cfs_cpt_table *cptab, char *buf, int len)
{
       return 0;
}
#endif /* CONFIG_SMP */

extern struct cfs_cpt_table	*cfs_cpt_table;

@@ -106,10 +122,6 @@ void cfs_cpt_table_free(struct cfs_cpt_table *cptab);
 * create a cfs_cpt_table with \a ncpt number of partitions
 */
struct cfs_cpt_table *cfs_cpt_table_alloc(unsigned int ncpt);
/**
 * print string information of cpt-table
 */
int cfs_cpt_table_print(struct cfs_cpt_table *cptab, char *buf, int len);
/**
 * return total number of CPU partitions in \a cptab
 */
@@ -123,10 +135,6 @@ int cfs_cpt_weight(struct cfs_cpt_table *cptab, int cpt);
 * is there any online CPU in CPU partition \a cpt
 */
int cfs_cpt_online(struct cfs_cpt_table *cptab, int cpt);
/**
 * return cpumask of CPU partition \a cpt
 */
cpumask_t *cfs_cpt_cpumask(struct cfs_cpt_table *cptab, int cpt);
/**
 * return nodemask of CPU partition \a cpt
 */
@@ -200,14 +208,6 @@ int cfs_cpt_spread_node(struct cfs_cpt_table *cptab, int cpt);
#define cfs_cpt_for_each(i, cptab)	\
	for (i = 0; i < cfs_cpt_number(cptab); i++)

#ifndef __read_mostly
# define __read_mostly
#endif

#ifndef ____cacheline_aligned
#define ____cacheline_aligned
#endif

int  cfs_cpu_init(void);
void cfs_cpu_fini(void);

+0 −6
Original line number Diff line number Diff line
@@ -81,12 +81,6 @@ struct cfs_cpt_table {
	nodemask_t			*ctb_nodemask;
};

void cfs_cpu_core_siblings(int cpu, cpumask_t *mask);
void cfs_cpu_ht_siblings(int cpu, cpumask_t *mask);
void cfs_node_to_cpumask(int node, cpumask_t *mask);
int cfs_cpu_core_nsiblings(int cpu);
int cfs_cpu_ht_nsiblings(int cpu);

/**
 * comment out definitions for compatible layer
 * #define CFS_CPU_NR			  NR_CPUS
+2 −0
Original line number Diff line number Diff line
@@ -702,6 +702,8 @@ kiblnd_get_completion_vector(kib_conn_t *conn, int cpt)
		return 0;

	mask = cfs_cpt_cpumask(lnet_cpt_table(), cpt);
	if (mask == NULL)
		return 0;

	/* hash NID to CPU id in this partition... */
	off = do_div(nid, cpus_weight(*mask));
+3 −43
Original line number Diff line number Diff line
@@ -76,62 +76,22 @@ struct cfs_cpt_data {

static struct cfs_cpt_data	cpt_data;

void
cfs_cpu_core_siblings(int cpu, cpumask_t *mask)
static void cfs_cpu_core_siblings(int cpu, cpumask_t *mask)
{
	/* return cpumask of cores in the same socket */
	cpumask_copy(mask, topology_core_cpumask(cpu));
}
EXPORT_SYMBOL(cfs_cpu_core_siblings);

/* return number of cores in the same socket of \a cpu */
int
cfs_cpu_core_nsiblings(int cpu)
{
	int	num;

	down(&cpt_data.cpt_mutex);

	cfs_cpu_core_siblings(cpu, cpt_data.cpt_cpumask);
	num = cpus_weight(*cpt_data.cpt_cpumask);

	up(&cpt_data.cpt_mutex);

	return num;
}
EXPORT_SYMBOL(cfs_cpu_core_nsiblings);

/* return cpumask of HTs in the same core */
void
cfs_cpu_ht_siblings(int cpu, cpumask_t *mask)
static void cfs_cpu_ht_siblings(int cpu, cpumask_t *mask)
{
	cpumask_copy(mask, topology_thread_cpumask(cpu));
}
EXPORT_SYMBOL(cfs_cpu_ht_siblings);

/* return number of HTs in the same core of \a cpu */
int
cfs_cpu_ht_nsiblings(int cpu)
{
	int	num;

	down(&cpt_data.cpt_mutex);

	cfs_cpu_ht_siblings(cpu, cpt_data.cpt_cpumask);
	num = cpus_weight(*cpt_data.cpt_cpumask);

	up(&cpt_data.cpt_mutex);

	return num;
}
EXPORT_SYMBOL(cfs_cpu_ht_nsiblings);

void
cfs_node_to_cpumask(int node, cpumask_t *mask)
static void cfs_node_to_cpumask(int node, cpumask_t *mask)
{
	cpumask_copy(mask, cpumask_of_node(node));
}
EXPORT_SYMBOL(cfs_node_to_cpumask);

void
cfs_cpt_table_free(struct cfs_cpt_table *cptab)
+9 −2
Original line number Diff line number Diff line
@@ -551,6 +551,7 @@ ptlrpc_server_nthreads_check(struct ptlrpc_service *svc,
	if (tc->tc_thr_factor != 0) {
		int	  factor = tc->tc_thr_factor;
		const int fade = 4;
		cpumask_t mask;

		/*
		 * User wants to increase number of threads with for
@@ -564,7 +565,8 @@ ptlrpc_server_nthreads_check(struct ptlrpc_service *svc,
		 * have too many threads no matter how many cores/HTs
		 * there are.
		 */
		if (cfs_cpu_ht_nsiblings(0) > 1) { /* weight is # of HTs */
		cpumask_copy(&mask, topology_thread_cpumask(0));
		if (cpus_weight(mask) > 1) { /* weight is # of HTs */
			/* depress thread factor for hyper-thread */
			factor = factor - (factor >> 1) + (factor >> 3);
		}
@@ -2776,11 +2778,13 @@ int ptlrpc_start_thread(struct ptlrpc_service_part *svcpt, int wait)

int ptlrpc_hr_init(void)
{
	cpumask_t			mask;
	struct ptlrpc_hr_partition	*hrp;
	struct ptlrpc_hr_thread		*hrt;
	int				rc;
	int				i;
	int				j;
	int				weight;
	ENTRY;

	memset(&ptlrpc_hr, 0, sizeof(ptlrpc_hr));
@@ -2793,6 +2797,9 @@ int ptlrpc_hr_init(void)

	init_waitqueue_head(&ptlrpc_hr.hr_waitq);

	cpumask_copy(&mask, topology_thread_cpumask(0));
	weight = cpus_weight(mask);

	cfs_percpt_for_each(hrp, i, ptlrpc_hr.hr_partitions) {
		hrp->hrp_cpt = i;

@@ -2800,7 +2807,7 @@ int ptlrpc_hr_init(void)
		atomic_set(&hrp->hrp_nstopped, 0);

		hrp->hrp_nthrs = cfs_cpt_weight(ptlrpc_hr.hr_cpt_table, i);
		hrp->hrp_nthrs /= cfs_cpu_ht_nsiblings(0);
		hrp->hrp_nthrs /= weight;

		LASSERT(hrp->hrp_nthrs > 0);
		OBD_CPT_ALLOC(hrp->hrp_thrs, ptlrpc_hr.hr_cpt_table, i,