1 // SPDX-License-Identifier: GPL-2.0-only 2 /* Unit tests for IIO formatting functions 3 * 4 * Copyright (c) 2020 Lars-Peter Clausen <lars@metafoo.de> 5 */ 6 7 #include <kunit/test.h> 8 #include <linux/iio/iio.h> 9 10 #define IIO_TEST_FORMAT_EXPECT_EQ(_test, _buf, _ret, _val) do { \ 11 KUNIT_EXPECT_EQ(_test, (int)strlen(_buf), _ret); \ 12 KUNIT_EXPECT_STREQ(_test, (_buf), (_val)); \ 13 } while (0) 14 15 static void iio_test_iio_format_value_integer(struct kunit *test) 16 { 17 char *buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL); 18 int val; 19 int ret; 20 21 val = 42; 22 ret = iio_format_value(buf, IIO_VAL_INT, 1, &val); 23 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "42\n"); 24 25 val = -23; 26 ret = iio_format_value(buf, IIO_VAL_INT, 1, &val); 27 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-23\n"); 28 29 val = 0; 30 ret = iio_format_value(buf, IIO_VAL_INT, 1, &val); 31 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0\n"); 32 33 val = INT_MAX; 34 ret = iio_format_value(buf, IIO_VAL_INT, 1, &val); 35 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "2147483647\n"); 36 37 val = INT_MIN; 38 ret = iio_format_value(buf, IIO_VAL_INT, 1, &val); 39 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-2147483648\n"); 40 } 41 42 static void iio_test_iio_format_value_fixedpoint(struct kunit *test) 43 { 44 char *buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL); 45 int values[2]; 46 int ret; 47 48 /* positive >= 1 */ 49 values[0] = 1; 50 values[1] = 10; 51 52 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO, 2, values); 53 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "1.000010\n"); 54 55 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO_DB, 2, values); 56 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "1.000010 dB\n"); 57 58 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_NANO, 2, values); 59 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "1.000000010\n"); 60 61 /* positive < 1 */ 62 values[0] = 0; 63 values[1] = 12; 64 65 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO, 2, values); 66 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.000012\n"); 67 68 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO_DB, 2, values); 69 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.000012 dB\n"); 70 71 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_NANO, 2, values); 72 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.000000012\n"); 73 74 /* negative <= -1 */ 75 values[0] = -1; 76 values[1] = 10; 77 78 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO, 2, values); 79 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-1.000010\n"); 80 81 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO_DB, 2, values); 82 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-1.000010 dB\n"); 83 84 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_NANO, 2, values); 85 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-1.000000010\n"); 86 87 /* negative > -1 */ 88 values[0] = 0; 89 values[1] = -123; 90 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO, 2, values); 91 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-0.000123\n"); 92 93 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_MICRO_DB, 2, values); 94 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-0.000123 dB\n"); 95 96 ret = iio_format_value(buf, IIO_VAL_INT_PLUS_NANO, 2, values); 97 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-0.000000123\n"); 98 } 99 100 static void iio_test_iio_format_value_fractional(struct kunit *test) 101 { 102 char *buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL); 103 int values[2]; 104 int ret; 105 106 /* positive < 1 */ 107 values[0] = 1; 108 values[1] = 10; 109 ret = iio_format_value(buf, IIO_VAL_FRACTIONAL, 2, values); 110 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.100000000\n"); 111 112 /* positive >= 1 */ 113 values[0] = 100; 114 values[1] = 3; 115 ret = iio_format_value(buf, IIO_VAL_FRACTIONAL, 2, values); 116 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "33.333333333\n"); 117 118 /* negative > -1 */ 119 values[0] = -1; 120 values[1] = 1000000000; 121 ret = iio_format_value(buf, IIO_VAL_FRACTIONAL, 2, values); 122 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-0.000000001\n"); 123 124 /* negative <= -1 */ 125 values[0] = -200; 126 values[1] = 3; 127 ret = iio_format_value(buf, IIO_VAL_FRACTIONAL, 2, values); 128 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-66.666666666\n"); 129 130 /* Zero */ 131 values[0] = 0; 132 values[1] = -10; 133 ret = iio_format_value(buf, IIO_VAL_FRACTIONAL, 2, values); 134 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.000000000\n"); 135 } 136 137 static void iio_test_iio_format_value_fractional_log2(struct kunit *test) 138 { 139 char *buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL); 140 int values[2]; 141 int ret; 142 143 /* positive < 1 */ 144 values[0] = 123; 145 values[1] = 10; 146 ret = iio_format_value(buf, IIO_VAL_FRACTIONAL_LOG2, 2, values); 147 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.120117187\n"); 148 149 /* positive >= 1 */ 150 values[0] = 1234567; 151 values[1] = 10; 152 ret = iio_format_value(buf, IIO_VAL_FRACTIONAL_LOG2, 2, values); 153 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "1205.631835937\n"); 154 155 /* negative > -1 */ 156 values[0] = -123; 157 values[1] = 10; 158 ret = iio_format_value(buf, IIO_VAL_FRACTIONAL_LOG2, 2, values); 159 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-0.120117187\n"); 160 161 /* negative <= -1 */ 162 values[0] = -1234567; 163 values[1] = 10; 164 ret = iio_format_value(buf, IIO_VAL_FRACTIONAL_LOG2, 2, values); 165 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "-1205.631835937\n"); 166 167 /* Zero */ 168 values[0] = 0; 169 values[1] = 10; 170 ret = iio_format_value(buf, IIO_VAL_FRACTIONAL_LOG2, 2, values); 171 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "0.000000000\n"); 172 } 173 174 static void iio_test_iio_format_value_multiple(struct kunit *test) 175 { 176 char *buf = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL); 177 int values[] = {1, -2, 3, -4, 5}; 178 int ret; 179 180 ret = iio_format_value(buf, IIO_VAL_INT_MULTIPLE, 181 ARRAY_SIZE(values), values); 182 IIO_TEST_FORMAT_EXPECT_EQ(test, buf, ret, "1 -2 3 -4 5 \n"); 183 } 184 185 static struct kunit_case iio_format_test_cases[] = { 186 KUNIT_CASE(iio_test_iio_format_value_integer), 187 KUNIT_CASE(iio_test_iio_format_value_fixedpoint), 188 KUNIT_CASE(iio_test_iio_format_value_fractional), 189 KUNIT_CASE(iio_test_iio_format_value_fractional_log2), 190 KUNIT_CASE(iio_test_iio_format_value_multiple), 191 {} 192 }; 193 194 static struct kunit_suite iio_format_test_suite = { 195 .name = "iio-format", 196 .test_cases = iio_format_test_cases, 197 }; 198 kunit_test_suite(iio_format_test_suite); 199