Commit 251ea0ca authored by Heiko Carstens's avatar Heiko Carstens Committed by Martin Schwidefsky
Browse files

s390/topology: get rid of core mask array



Use a single long value instead of a single element array to represent
the core mask. The array is a leftover from 32/31 bit code so we were
able to use bitops helper functions.

Signed-off-by: default avatarHeiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
parent 9b62330f
Loading
Loading
Loading
Loading
+1 −2
Original line number Diff line number Diff line
@@ -142,7 +142,6 @@ struct sysinfo_3_2_2 {

extern int topology_max_mnest;

#define TOPOLOGY_CORE_BITS	64
#define TOPOLOGY_NR_MAG		6

struct topology_core {
@@ -152,7 +151,7 @@ struct topology_core {
	unsigned char pp:2;
	unsigned char reserved1;
	unsigned short origin;
	unsigned long mask[TOPOLOGY_CORE_BITS / BITS_PER_LONG];
	unsigned long mask;
};

struct topology_container {
+3 −1
Original line number Diff line number Diff line
@@ -83,6 +83,8 @@ static cpumask_t cpu_thread_map(unsigned int cpu)
	return mask;
}

#define TOPOLOGY_CORE_BITS	64

static void add_cpus_to_mask(struct topology_core *tl_core,
			     struct mask_info *drawer,
			     struct mask_info *book,
@@ -91,7 +93,7 @@ static void add_cpus_to_mask(struct topology_core *tl_core,
	struct cpu_topology_s390 *topo;
	unsigned int core;

	for_each_set_bit(core, &tl_core->mask[0], TOPOLOGY_CORE_BITS) {
	for_each_set_bit(core, &tl_core->mask, TOPOLOGY_CORE_BITS) {
		unsigned int rcore;
		int lcpu, i;