[PATCH 7/7] binman: Refuse to replace sections for now
Simon Glass
sjg at chromium.org
Tue Apr 19 23:54:13 CEST 2022
On Sun, 27 Mar 2022 at 09:32, Alper Nebi Yasak <alpernebiyasak at gmail.com> wrote:
>
> Binman interfaces allow attempts to replace any entry in the image with
> arbitrary data. When trying to replace sections, the changes in the
> section entry's data are not propagated to its child entries. This,
> combined with how sections rebuild their contents from its children,
> eventually causes the replaced contents to be silently overwritten by
> rebuilt contents equivalent to the original data.
>
> Add a simple test for replacing a section that is currently failing due
> to this behaviour, and mark it as an expected failure. Also, raise an
> error when replacing a section instead of silently pretending it was
> replaced.
>
> Signed-off-by: Alper Nebi Yasak <alpernebiyasak at gmail.com>
> ---
>
> tools/binman/etype/section.py | 3 +++
> tools/binman/ftest.py | 9 ++++++++
> .../test/234_replace_section_simple.dts | 23 +++++++++++++++++++
> 3 files changed, 35 insertions(+)
> create mode 100644 tools/binman/test/234_replace_section_simple.dts
Reviewed-by: Simon Glass <sjg at chromium.org>
Is it not better to assertRaises() and check that the error message is
as expected?
>
> diff --git a/tools/binman/etype/section.py b/tools/binman/etype/section.py
> index ccac658c1831..bd67238b9199 100644
> --- a/tools/binman/etype/section.py
> +++ b/tools/binman/etype/section.py
> @@ -788,6 +788,9 @@ def ReadChildData(self, child, decomp=True, alt_format=None):
> data = new_data
> return data
>
> + def WriteData(self, data, decomp=True):
> + self.Raise("Replacing sections is not implemented yet")
> +
> def WriteChildData(self, child):
> return True
>
> diff --git a/tools/binman/ftest.py b/tools/binman/ftest.py
> index 43bec4a88841..058651cc18a0 100644
> --- a/tools/binman/ftest.py
> +++ b/tools/binman/ftest.py
> @@ -5641,6 +5641,15 @@ def testReplaceFitSubentryLeafSmallerSize(self):
> self.assertIsNotNone(path)
> self.assertEqual(expected_fdtmap, fdtmap)
>
> + @unittest.expectedFailure
> + def testReplaceSectionSimple(self):
> + """Test replacing a simple section with arbitrary data"""
> + new_data = b'w' * len(COMPRESS_DATA + U_BOOT_DATA)
> + data, expected_fdtmap, _ = self._RunReplaceCmd(
> + 'section', new_data,
> + dts='234_replace_section_simple.dts')
> + self.assertEqual(new_data, data)
> +
>
> if __name__ == "__main__":
> unittest.main()
> diff --git a/tools/binman/test/234_replace_section_simple.dts b/tools/binman/test/234_replace_section_simple.dts
> new file mode 100644
> index 000000000000..c9d5c3285615
> --- /dev/null
> +++ b/tools/binman/test/234_replace_section_simple.dts
> @@ -0,0 +1,23 @@
> +// SPDX-License-Identifier: GPL-2.0+
> +/dts-v1/;
> +
> +/ {
> + binman {
> + allow-repack;
> +
> + u-boot-dtb {
> + };
> +
> + section {
> + blob {
> + filename = "compress";
> + };
> +
> + u-boot {
> + };
> + };
> +
> + fdtmap {
> + };
> + };
> +};
> --
> 2.35.1
>
More information about the U-Boot
mailing list