Skip to content

Commit 721f4a6

Browse files
RichardWeiYangrppt
authored andcommitted
mm/memblock: remove empty dummy entry
The dummy entry is introduced in the initial implementation of lmb in commit 7c8c6b9 ("powerpc: Merge lmb.c and make MM initialization use it."). As the comment says the empty dummy entry is to simplify the code. /* Create a dummy zero size LMB which will get coalesced away later. * This simplifies the lmb_add() code below... */ While current code is reimplemented by Tejun in commit 784656f ("memblock: Reimplement memblock_add_region()"). This empty dummy entry seems not benefit the code any more. Let's remove it. Signed-off-by: Wei Yang <[email protected]> CC: Paul Mackerras <[email protected]> CC: Tejun Heo <[email protected]> CC: Mike Rapoport <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Mike Rapoport (IBM) <[email protected]>
1 parent c3f38fa commit 721f4a6

File tree

3 files changed

+8
-11
lines changed

3 files changed

+8
-11
lines changed

mm/memblock.c

Lines changed: 2 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -114,12 +114,10 @@ static struct memblock_region memblock_physmem_init_regions[INIT_PHYSMEM_REGIONS
114114

115115
struct memblock memblock __initdata_memblock = {
116116
.memory.regions = memblock_memory_init_regions,
117-
.memory.cnt = 1, /* empty dummy entry */
118117
.memory.max = INIT_MEMBLOCK_MEMORY_REGIONS,
119118
.memory.name = "memory",
120119

121120
.reserved.regions = memblock_reserved_init_regions,
122-
.reserved.cnt = 1, /* empty dummy entry */
123121
.reserved.max = INIT_MEMBLOCK_RESERVED_REGIONS,
124122
.reserved.name = "reserved",
125123

@@ -130,7 +128,6 @@ struct memblock memblock __initdata_memblock = {
130128
#ifdef CONFIG_HAVE_MEMBLOCK_PHYS_MAP
131129
struct memblock_type physmem = {
132130
.regions = memblock_physmem_init_regions,
133-
.cnt = 1, /* empty dummy entry */
134131
.max = INIT_PHYSMEM_REGIONS,
135132
.name = "physmem",
136133
};
@@ -356,7 +353,6 @@ static void __init_memblock memblock_remove_region(struct memblock_type *type, u
356353
/* Special case for empty arrays */
357354
if (type->cnt == 0) {
358355
WARN_ON(type->total_size != 0);
359-
type->cnt = 1;
360356
type->regions[0].base = 0;
361357
type->regions[0].size = 0;
362358
type->regions[0].flags = 0;
@@ -600,12 +596,13 @@ static int __init_memblock memblock_add_range(struct memblock_type *type,
600596

601597
/* special case for empty array */
602598
if (type->regions[0].size == 0) {
603-
WARN_ON(type->cnt != 1 || type->total_size);
599+
WARN_ON(type->cnt != 0 || type->total_size);
604600
type->regions[0].base = base;
605601
type->regions[0].size = size;
606602
type->regions[0].flags = flags;
607603
memblock_set_region_node(&type->regions[0], nid);
608604
type->total_size = size;
605+
type->cnt = 1;
609606
return 0;
610607
}
611608

tools/testing/memblock/tests/basic_api.c

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -15,12 +15,12 @@ static int memblock_initialization_check(void)
1515
PREFIX_PUSH();
1616

1717
ASSERT_NE(memblock.memory.regions, NULL);
18-
ASSERT_EQ(memblock.memory.cnt, 1);
18+
ASSERT_EQ(memblock.memory.cnt, 0);
1919
ASSERT_EQ(memblock.memory.max, EXPECTED_MEMBLOCK_REGIONS);
2020
ASSERT_EQ(strcmp(memblock.memory.name, "memory"), 0);
2121

2222
ASSERT_NE(memblock.reserved.regions, NULL);
23-
ASSERT_EQ(memblock.reserved.cnt, 1);
23+
ASSERT_EQ(memblock.reserved.cnt, 0);
2424
ASSERT_EQ(memblock.memory.max, EXPECTED_MEMBLOCK_REGIONS);
2525
ASSERT_EQ(strcmp(memblock.reserved.name, "reserved"), 0);
2626

@@ -1295,7 +1295,7 @@ static int memblock_remove_only_region_check(void)
12951295
ASSERT_EQ(rgn->base, 0);
12961296
ASSERT_EQ(rgn->size, 0);
12971297

1298-
ASSERT_EQ(memblock.memory.cnt, 1);
1298+
ASSERT_EQ(memblock.memory.cnt, 0);
12991299
ASSERT_EQ(memblock.memory.total_size, 0);
13001300

13011301
test_pass_pop();
@@ -1723,7 +1723,7 @@ static int memblock_free_only_region_check(void)
17231723
ASSERT_EQ(rgn->base, 0);
17241724
ASSERT_EQ(rgn->size, 0);
17251725

1726-
ASSERT_EQ(memblock.reserved.cnt, 1);
1726+
ASSERT_EQ(memblock.reserved.cnt, 0);
17271727
ASSERT_EQ(memblock.reserved.total_size, 0);
17281728

17291729
test_pass_pop();

tools/testing/memblock/tests/common.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -40,13 +40,13 @@ void reset_memblock_regions(void)
4040
{
4141
memset(memblock.memory.regions, 0,
4242
memblock.memory.cnt * sizeof(struct memblock_region));
43-
memblock.memory.cnt = 1;
43+
memblock.memory.cnt = 0;
4444
memblock.memory.max = INIT_MEMBLOCK_REGIONS;
4545
memblock.memory.total_size = 0;
4646

4747
memset(memblock.reserved.regions, 0,
4848
memblock.reserved.cnt * sizeof(struct memblock_region));
49-
memblock.reserved.cnt = 1;
49+
memblock.reserved.cnt = 0;
5050
memblock.reserved.max = INIT_MEMBLOCK_RESERVED_REGIONS;
5151
memblock.reserved.total_size = 0;
5252
}

0 commit comments

Comments
 (0)