diff mbox series

[U-Boot,v2,6/6] test: smem: add basic smem test

Message ID 20180622021133.24062-7-ramon.fried@gmail.com
State Superseded
Headers show
Series [U-Boot,v2,1/6] dm: SMEM (Shared memory) uclass | expand

Commit Message

Ramon Fried June 22, 2018, 2:11 a.m. UTC
Add basic smem sandbox testing.

Signed-off-by: Ramon Fried <ramon.fried@gmail.com>

---
Tom, this patch depends on https://patchwork.ozlabs.org/patch/932965/

Changes in v2: None

 test/dm/Makefile |  1 +
 test/dm/smem.c   | 29 +++++++++++++++++++++++++++++
 2 files changed, 30 insertions(+)
 create mode 100644 test/dm/smem.c

Comments

Simon Glass June 26, 2018, 3:59 a.m. UTC | #1
On 21 June 2018 at 20:11, Ramon Fried <ramon.fried@gmail.com> wrote:
> Add basic smem sandbox testing.
>
> Signed-off-by: Ramon Fried <ramon.fried@gmail.com>
>
> ---
> Tom, this patch depends on https://patchwork.ozlabs.org/patch/932965/
>
> Changes in v2: None
>
>  test/dm/Makefile |  1 +
>  test/dm/smem.c   | 29 +++++++++++++++++++++++++++++
>  2 files changed, 30 insertions(+)
>  create mode 100644 test/dm/smem.c

Reviewed-by: Simon Glass <sjg@chromium.org>
diff mbox series

Patch

diff --git a/test/dm/Makefile b/test/dm/Makefile
index 5511a85700..d2ed96c615 100644
--- a/test/dm/Makefile
+++ b/test/dm/Makefile
@@ -33,6 +33,7 @@  obj-$(CONFIG_DM_RESET) += reset.o
 obj-$(CONFIG_SYSRESET) += sysreset.o
 obj-$(CONFIG_DM_RTC) += rtc.o
 obj-$(CONFIG_DM_SPI_FLASH) += sf.o
+obj-$(CONFIG_SMEM) += smem.o
 obj-$(CONFIG_DM_SPI) += spi.o
 obj-y += syscon.o
 obj-$(CONFIG_DM_USB) += usb.o
diff --git a/test/dm/smem.c b/test/dm/smem.c
new file mode 100644
index 0000000000..4d94ddbe5b
--- /dev/null
+++ b/test/dm/smem.c
@@ -0,0 +1,29 @@ 
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright (C) 2018 Ramon Fried <ramon.fried@gmail.com>
+ */
+
+#include <common.h>
+#include <dm.h>
+#include <smem.h>
+#include <dm/test.h>
+#include <test/ut.h>
+
+/* Basic test of the smem uclass */
+static int dm_test_smem_base(struct unit_test_state *uts)
+{
+	struct udevice *dev;
+	size_t size;
+
+	ut_assertok(uclass_get_device(UCLASS_SMEM, 0, &dev));
+	ut_assertnonnull(dev);
+	ut_assertok(smem_alloc(dev, -1, 0, 16));
+	ut_assertok(smem_get_free_space(dev, -1, &size);
+	ut_assertnonnull(smem_get(dev, -1, 0, &size));
+	/* Try getting of bound item */
+	ut_assertnnull(smem_get(dev, -1, 70, &size));
+
+	return 0;
+}
+DM_TEST(dm_test_smem_base, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
+