提交 2f7d03e0 编写于 作者: B Bharata B Rao 提交者: Michael Ellerman

powerpc/mm/drmem: Fix unexpected flag value in ibm,dynamic-memory-v2

Memory addtion and removal by count and indexed-count methods
temporarily mark the LMBs that are being added/removed by a special
flag value DRMEM_LMB_RESERVED. Accessing flags value directly at a few
places without proper accessor method is causing two unexpected
side-effects:

- DRMEM_LMB_RESERVED bit is becoming part of the flags word of
  drconf_cell_v2 entries in ibm,dynamic-memory-v2 DT property.
- This results in extra drconf_cell entries in ibm,dynamic-memory-v2.
  For example if 1G memory is added, it leads to one entry for 3 LMBs
  and 1 separate entry for the last LMB. All the 4 LMBs should be
  defined by one entry here.

Fix this by always accessing the flags by its accessor method
drmem_lmb_flags().

Fixes: 2b31e3ae ("powerpc/drmem: Add support for ibm, dynamic-memory-v2 property")
Signed-off-by: NBharata B Rao <bharata@linux.vnet.ibm.com>
Reviewed-by: NNathan Fontenot <nfont@linux.vnet.ibm.com>
Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
上级 083b2090
...@@ -98,7 +98,7 @@ static void init_drconf_v2_cell(struct of_drconf_cell_v2 *dr_cell, ...@@ -98,7 +98,7 @@ static void init_drconf_v2_cell(struct of_drconf_cell_v2 *dr_cell,
dr_cell->base_addr = cpu_to_be64(lmb->base_addr); dr_cell->base_addr = cpu_to_be64(lmb->base_addr);
dr_cell->drc_index = cpu_to_be32(lmb->drc_index); dr_cell->drc_index = cpu_to_be32(lmb->drc_index);
dr_cell->aa_index = cpu_to_be32(lmb->aa_index); dr_cell->aa_index = cpu_to_be32(lmb->aa_index);
dr_cell->flags = cpu_to_be32(lmb->flags); dr_cell->flags = cpu_to_be32(drmem_lmb_flags(lmb));
} }
static int drmem_update_dt_v2(struct device_node *memory, static int drmem_update_dt_v2(struct device_node *memory,
...@@ -121,7 +121,7 @@ static int drmem_update_dt_v2(struct device_node *memory, ...@@ -121,7 +121,7 @@ static int drmem_update_dt_v2(struct device_node *memory,
} }
if (prev_lmb->aa_index != lmb->aa_index || if (prev_lmb->aa_index != lmb->aa_index ||
prev_lmb->flags != lmb->flags) drmem_lmb_flags(prev_lmb) != drmem_lmb_flags(lmb))
lmb_sets++; lmb_sets++;
prev_lmb = lmb; prev_lmb = lmb;
...@@ -150,7 +150,7 @@ static int drmem_update_dt_v2(struct device_node *memory, ...@@ -150,7 +150,7 @@ static int drmem_update_dt_v2(struct device_node *memory,
} }
if (prev_lmb->aa_index != lmb->aa_index || if (prev_lmb->aa_index != lmb->aa_index ||
prev_lmb->flags != lmb->flags) { drmem_lmb_flags(prev_lmb) != drmem_lmb_flags(lmb)) {
/* end of one set, start of another */ /* end of one set, start of another */
dr_cell->seq_lmbs = cpu_to_be32(seq_lmbs); dr_cell->seq_lmbs = cpu_to_be32(seq_lmbs);
dr_cell++; dr_cell++;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册