提交 55cef91a 编写于 作者: P Paul Mundt

sh: Prevent fixed slot PMB remapping from clobbering boot entries.

The PMB initialization code walks the entries and synchronizes the
software PMB state with the hardware mappings, preserving the slot index.
Unfortunately pmb_alloc() only tested the bit position in the entry map
and failed to set it, resulting in subsequent remaps being able to be
dynamically assigned a slot that trampled an existing boot mapping with
general badness ensuing.
Signed-off-by: NPaul Mundt <lethal@linux-sh.org>
上级 319c2cc7
...@@ -77,7 +77,7 @@ static struct pmb_entry *pmb_alloc(unsigned long vpn, unsigned long ppn, ...@@ -77,7 +77,7 @@ static struct pmb_entry *pmb_alloc(unsigned long vpn, unsigned long ppn,
if (pos < 0) if (pos < 0)
return ERR_PTR(pos); return ERR_PTR(pos);
} else { } else {
if (test_bit(entry, &pmb_map)) if (test_and_set_bit(entry, &pmb_map))
return ERR_PTR(-ENOSPC); return ERR_PTR(-ENOSPC);
pos = entry; pos = entry;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册