272 lines
8.4 KiB
C
272 lines
8.4 KiB
C
|
// SPDX-License-Identifier: GPL-2.0-only
|
||
|
/* Unit tests for IIO formatting functions
|
||
|
*
|
||
|
* Copyright (c) 2020 Lars-Peter Clausen <lars@metafoo.de>
|
||
|
*/
|
||
|
|
||
|
#include <kunit/test.h>
|
||
|
#include <linux/iio/iio.h>
|
||
|
|
||
|
#define IIO_TEST_FORMAT_EXPECT_EQ(_test, _buf, _ret, _val) do { \
|
||
|
KUNIT_EXPECT_EQ(_test, strlen(_buf), _ret); \
|
||
|
KUNIT_EXPECT_STREQ(_test, (_buf), (_val)); \
|
||
|
} while (0)
|
||
|
|
||
|
static void iio_test_iio_format_value_integer(struct kunit *test)
|
||
|
{
|
||
|
char *buf;
|
||
|
int val;
|
||
|
int ret;
|
||
|
|
||
|
buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL);
|
||
|
KUNIT_ASSERT_NOT_ERR_OR_NULL(test, buf);
|
||
|
|
||
|
val = 42;
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT, 1, &val);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "42\n");
|
||
|
|
||
|
val = -23;
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT, 1, &val);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-23\n");
|
||
|
|
||
|
val = 0;
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT, 1, &val);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0\n");
|
||
|
|
||
|
val = INT_MAX;
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT, 1, &val);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "2147483647\n");
|
||
|
|
||
|
val = INT_MIN;
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT, 1, &val);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-2147483648\n");
|
||
|
}
|
||
|
|
||
|
static void iio_test_iio_format_value_fixedpoint(struct kunit *test)
|
||
|
{
|
||
|
int values[2];
|
||
|
char *buf;
|
||
|
int ret;
|
||
|
|
||
|
buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL);
|
||
|
KUNIT_ASSERT_NOT_ERR_OR_NULL(test, buf);
|
||
|
|
||
|
/* positive >= 1 */
|
||
|
values[0] = 1;
|
||
|
values[1] = 10;
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "1.000010\n");
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO_DB, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "1.000010 dB\n");
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_NANO, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "1.000000010\n");
|
||
|
|
||
|
/* positive < 1 */
|
||
|
values[0] = 0;
|
||
|
values[1] = 12;
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.000012\n");
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO_DB, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.000012 dB\n");
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_NANO, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.000000012\n");
|
||
|
|
||
|
/* negative <= -1 */
|
||
|
values[0] = -1;
|
||
|
values[1] = 10;
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-1.000010\n");
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO_DB, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-1.000010 dB\n");
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_NANO, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-1.000000010\n");
|
||
|
|
||
|
/* negative > -1 */
|
||
|
values[0] = 0;
|
||
|
values[1] = -123;
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-0.000123\n");
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO_DB, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-0.000123 dB\n");
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_PLUS_NANO, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-0.000000123\n");
|
||
|
}
|
||
|
|
||
|
static void iio_test_iio_format_value_fractional(struct kunit *test)
|
||
|
{
|
||
|
int values[2];
|
||
|
char *buf;
|
||
|
int ret;
|
||
|
|
||
|
buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL);
|
||
|
KUNIT_ASSERT_NOT_ERR_OR_NULL(test, buf);
|
||
|
|
||
|
/* positive < 1 */
|
||
|
values[0] = 1;
|
||
|
values[1] = 10;
|
||
|
ret = iio_format_value(buf, IIO_VAL_FRACTIONAL, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.100000000\n");
|
||
|
|
||
|
/* positive >= 1 */
|
||
|
values[0] = 100;
|
||
|
values[1] = 3;
|
||
|
ret = iio_format_value(buf, IIO_VAL_FRACTIONAL, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "33.333333333\n");
|
||
|
|
||
|
/* negative > -1 */
|
||
|
values[0] = -1;
|
||
|
values[1] = 1000000000;
|
||
|
ret = iio_format_value(buf, IIO_VAL_FRACTIONAL, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-0.000000001\n");
|
||
|
|
||
|
/* negative <= -1 */
|
||
|
values[0] = -200;
|
||
|
values[1] = 3;
|
||
|
ret = iio_format_value(buf, IIO_VAL_FRACTIONAL, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-66.666666666\n");
|
||
|
|
||
|
/* Zero */
|
||
|
values[0] = 0;
|
||
|
values[1] = -10;
|
||
|
ret = iio_format_value(buf, IIO_VAL_FRACTIONAL, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.000000000\n");
|
||
|
}
|
||
|
|
||
|
static void iio_test_iio_format_value_fractional_log2(struct kunit *test)
|
||
|
{
|
||
|
int values[2];
|
||
|
char *buf;
|
||
|
int ret;
|
||
|
|
||
|
buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL);
|
||
|
KUNIT_ASSERT_NOT_ERR_OR_NULL(test, buf);
|
||
|
|
||
|
/* positive < 1 */
|
||
|
values[0] = 123;
|
||
|
values[1] = 10;
|
||
|
ret = iio_format_value(buf, IIO_VAL_FRACTIONAL_LOG2, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.120117187\n");
|
||
|
|
||
|
/* positive >= 1 */
|
||
|
values[0] = 1234567;
|
||
|
values[1] = 10;
|
||
|
ret = iio_format_value(buf, IIO_VAL_FRACTIONAL_LOG2, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "1205.631835937\n");
|
||
|
|
||
|
/* negative > -1 */
|
||
|
values[0] = -123;
|
||
|
values[1] = 10;
|
||
|
ret = iio_format_value(buf, IIO_VAL_FRACTIONAL_LOG2, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-0.120117187\n");
|
||
|
|
||
|
/* negative <= -1 */
|
||
|
values[0] = -1234567;
|
||
|
values[1] = 10;
|
||
|
ret = iio_format_value(buf, IIO_VAL_FRACTIONAL_LOG2, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-1205.631835937\n");
|
||
|
|
||
|
/* Zero */
|
||
|
values[0] = 0;
|
||
|
values[1] = 10;
|
||
|
ret = iio_format_value(buf, IIO_VAL_FRACTIONAL_LOG2, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.000000000\n");
|
||
|
}
|
||
|
|
||
|
static void iio_test_iio_format_value_multiple(struct kunit *test)
|
||
|
{
|
||
|
int values[] = {1, -2, 3, -4, 5};
|
||
|
char *buf;
|
||
|
int ret;
|
||
|
|
||
|
buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL);
|
||
|
KUNIT_ASSERT_NOT_ERR_OR_NULL(test, buf);
|
||
|
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_MULTIPLE,
|
||
|
ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "1 -2 3 -4 5 \n");
|
||
|
}
|
||
|
|
||
|
static void iio_test_iio_format_value_integer_64(struct kunit *test)
|
||
|
{
|
||
|
int values[2];
|
||
|
s64 value;
|
||
|
char *buf;
|
||
|
int ret;
|
||
|
|
||
|
buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL);
|
||
|
KUNIT_ASSERT_NOT_ERR_OR_NULL(test, buf);
|
||
|
|
||
|
value = 24;
|
||
|
values[0] = lower_32_bits(value);
|
||
|
values[1] = upper_32_bits(value);
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_64, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "24\n");
|
||
|
|
||
|
value = -24;
|
||
|
values[0] = lower_32_bits(value);
|
||
|
values[1] = upper_32_bits(value);
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_64, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-24\n");
|
||
|
|
||
|
value = 0;
|
||
|
values[0] = lower_32_bits(value);
|
||
|
values[1] = upper_32_bits(value);
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_64, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0\n");
|
||
|
|
||
|
value = UINT_MAX;
|
||
|
values[0] = lower_32_bits(value);
|
||
|
values[1] = upper_32_bits(value);
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_64, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "4294967295\n");
|
||
|
|
||
|
value = -((s64)UINT_MAX);
|
||
|
values[0] = lower_32_bits(value);
|
||
|
values[1] = upper_32_bits(value);
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_64, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-4294967295\n");
|
||
|
|
||
|
value = LLONG_MAX;
|
||
|
values[0] = lower_32_bits(value);
|
||
|
values[1] = upper_32_bits(value);
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_64, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "9223372036854775807\n");
|
||
|
|
||
|
value = LLONG_MIN;
|
||
|
values[0] = lower_32_bits(value);
|
||
|
values[1] = upper_32_bits(value);
|
||
|
ret = iio_format_value(buf, IIO_VAL_INT_64, ARRAY_SIZE(values), values);
|
||
|
IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-9223372036854775808\n");
|
||
|
}
|
||
|
|
||
|
static struct kunit_case iio_format_test_cases[] = {
|
||
|
KUNIT_CASE(iio_test_iio_format_value_integer),
|
||
|
KUNIT_CASE(iio_test_iio_format_value_fixedpoint),
|
||
|
KUNIT_CASE(iio_test_iio_format_value_fractional),
|
||
|
KUNIT_CASE(iio_test_iio_format_value_fractional_log2),
|
||
|
KUNIT_CASE(iio_test_iio_format_value_multiple),
|
||
|
KUNIT_CASE(iio_test_iio_format_value_integer_64),
|
||
|
{}
|
||
|
};
|
||
|
|
||
|
static struct kunit_suite iio_format_test_suite = {
|
||
|
.name = "iio-format",
|
||
|
.test_cases = iio_format_test_cases,
|
||
|
};
|
||
|
kunit_test_suite(iio_format_test_suite);
|
||
|
|
||
|
MODULE_AUTHOR("Lars-Peter Clausen <lars@metafoo.de>");
|
||
|
MODULE_DESCRIPTION("Test IIO formatting functions");
|
||
|
MODULE_LICENSE("GPL v2");
|