[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250522080656.1215457-4-lee@kernel.org>
Date: Thu, 22 May 2025 09:06:51 +0100
From: Lee Jones <lee@...nel.org>
To: lee@...nel.org,
Pavel Machek <pavel@...nel.org>,
linux-leds@...r.kernel.org,
linux-kernel@...r.kernel.org
Cc: bettyzhou@...gle.com,
ynaffit@...gle.com,
tkjos@...gle.com,
jacek.anaszewski@...il.com
Subject: [PATCH v3 4/5] leds: led-test: Provide test for registration with a name that is too long
Insist on non-DT registration with init_data whilst providing a
default_label and devicename that when concatenated together results in
a device name that is unacceptably long.
Signed-off-by: Lee Jones <lee@...nel.org>
Reviewed-by: Jacek Anaszewski <jacek.anaszewski@...il.com>
---
drivers/leds/led-test.c | 17 +++++++++++++++++
1 file changed, 17 insertions(+)
diff --git a/drivers/leds/led-test.c b/drivers/leds/led-test.c
index d378c905546b..d5017c6dca08 100644
--- a/drivers/leds/led-test.c
+++ b/drivers/leds/led-test.c
@@ -123,11 +123,28 @@ static void led_test_class_init_data_missing_devicename(struct kunit *test)
KUNIT_EXPECT_EQ(test, ret, -EINVAL);
}
+static void led_test_class_init_data_name_too_long(struct kunit *test)
+{
+ struct led_test_ddata *ddata = test->priv;
+ struct led_classdev *cdev = &ddata->cdev;
+ struct device *dev = ddata->dev;
+ int ret;
+
+ struct led_init_data init_data = {
+ .devicename = "led-test-devicename-very-long-names-fail",
+ .default_label = "led-test-label-also-very-long-names-fail",
+ };
+
+ ret = devm_led_classdev_register_ext(dev, cdev, &init_data);
+ KUNIT_EXPECT_EQ(test, ret, -E2BIG);
+}
+
static struct kunit_case led_test_cases[] = {
KUNIT_CASE(led_test_class_register),
KUNIT_CASE(led_test_class_add_lookup_and_get),
KUNIT_CASE(led_test_class_init_data_missing_default_label),
KUNIT_CASE(led_test_class_init_data_missing_devicename),
+ KUNIT_CASE(led_test_class_init_data_name_too_long),
{ }
};
--
2.49.0.1143.g0be31eac6b-goog
Powered by blists - more mailing lists