arm64: dts: qcom: sm8550: add TRNG node
[linux-modified.git] / drivers / iio / test / iio-test-rescale.c
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Kunit tests for IIO rescale conversions
4  *
5  * Copyright (c) 2021 Liam Beguin <liambeguin@gmail.com>
6  */
7
8 #include <linux/gcd.h>
9 #include <linux/overflow.h>
10
11 #include <linux/iio/afe/rescale.h>
12 #include <linux/iio/iio.h>
13
14 #include <kunit/test.h>
15
16 struct rescale_tc_data {
17         const char *name;
18
19         const s32 numerator;
20         const s32 denominator;
21         const s32 offset;
22
23         const int schan_val;
24         const int schan_val2;
25         const int schan_off;
26         const int schan_scale_type;
27
28         const char *expected;
29         const char *expected_off;
30 };
31
32 static const struct rescale_tc_data scale_cases[] = {
33         /*
34          * Typical use cases
35          */
36         {
37                 .name = "typical IIO_VAL_INT, positive",
38                 .numerator = 1000000,
39                 .denominator = 8060,
40                 .schan_scale_type = IIO_VAL_INT,
41                 .schan_val = 42,
42                 .expected = "5210.918114143",
43         },
44         {
45                 .name = "typical IIO_VAL_INT, negative",
46                 .numerator = -1000000,
47                 .denominator = 8060,
48                 .schan_scale_type = IIO_VAL_INT,
49                 .schan_val = 42,
50                 .expected = "-5210.918114143",
51         },
52         {
53                 .name = "typical IIO_VAL_FRACTIONAL, positive",
54                 .numerator = 1000000,
55                 .denominator = 8060,
56                 .schan_scale_type = IIO_VAL_FRACTIONAL,
57                 .schan_val = 42,
58                 .schan_val2 = 20,
59                 .expected = "260.545905707",
60         },
61         {
62                 .name = "typical IIO_VAL_FRACTIONAL, negative",
63                 .numerator = -1000000,
64                 .denominator = 8060,
65                 .schan_scale_type = IIO_VAL_FRACTIONAL,
66                 .schan_val = 42,
67                 .schan_val2 = 20,
68                 .expected = "-260.545905707",
69         },
70         {
71                 .name = "typical IIO_VAL_FRACTIONAL_LOG2, positive",
72                 .numerator = 42,
73                 .denominator = 53,
74                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
75                 .schan_val = 4096,
76                 .schan_val2 = 16,
77                 .expected = "0.049528301",
78         },
79         {
80                 .name = "typical IIO_VAL_FRACTIONAL_LOG2, negative",
81                 .numerator = -42,
82                 .denominator = 53,
83                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
84                 .schan_val = 4096,
85                 .schan_val2 = 16,
86                 .expected = "-0.049528301",
87         },
88         {
89                 .name = "typical IIO_VAL_INT_PLUS_NANO, positive",
90                 .numerator = 1000000,
91                 .denominator = 8060,
92                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
93                 .schan_val = 10,
94                 .schan_val2 = 123456,
95                 .expected = "1240.710106203",
96         },
97         {
98                 .name = "typical IIO_VAL_INT_PLUS_NANO, negative",
99                 .numerator = -1000000,
100                 .denominator = 8060,
101                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
102                 .schan_val = 10,
103                 .schan_val2 = 123456,
104                 .expected = "-1240.710106203",
105         },
106         {
107                 .name = "typical IIO_VAL_INT_PLUS_MICRO, positive",
108                 .numerator = 1000000,
109                 .denominator = 8060,
110                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
111                 .schan_val = 10,
112                 .schan_val2 = 1234,
113                 .expected = "1240.84789",
114         },
115         {
116                 .name = "typical IIO_VAL_INT_PLUS_MICRO, negative",
117                 .numerator = -1000000,
118                 .denominator = 8060,
119                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
120                 .schan_val = 10,
121                 .schan_val2 = 1234,
122                 .expected = "-1240.84789",
123         },
124         /*
125          * Use cases with small scales involving divisions
126          */
127         {
128                 .name = "small IIO_VAL_FRACTIONAL, 261/509 scaled by 90/1373754273",
129                 .numerator = 261,
130                 .denominator = 509,
131                 .schan_scale_type = IIO_VAL_FRACTIONAL,
132                 .schan_val = 90,
133                 .schan_val2 = 1373754273,
134                 .expected = "0.000000033594",
135         },
136         {
137                 .name = "small IIO_VAL_FRACTIONAL, 90/1373754273 scaled by 261/509",
138                 .numerator = 90,
139                 .denominator = 1373754273,
140                 .schan_scale_type = IIO_VAL_FRACTIONAL,
141                 .schan_val = 261,
142                 .schan_val2 = 509,
143                 .expected = "0.000000033594",
144         },
145         {
146                 .name = "small IIO_VAL_FRACTIONAL, 760/1373754273 scaled by 427/2727",
147                 .numerator = 760,
148                 .denominator = 1373754273,
149                 .schan_scale_type = IIO_VAL_FRACTIONAL,
150                 .schan_val = 427,
151                 .schan_val2 = 2727,
152                 .expected = "0.000000086626",
153         },
154         {
155                 .name = "small IIO_VAL_FRACTIONAL, 761/1373754273 scaled by 427/2727",
156                 .numerator = 761,
157                 .denominator = 1373754273,
158                 .schan_scale_type = IIO_VAL_FRACTIONAL,
159                 .schan_val = 427,
160                 .schan_val2 = 2727,
161                 .expected = "0.000000086740",
162         },
163         {
164                 .name = "small IIO_VAL_FRACTIONAL, 5/32768 scaled by 3/10000",
165                 .numerator = 5,
166                 .denominator = 32768,
167                 .schan_scale_type = IIO_VAL_FRACTIONAL,
168                 .schan_val = 3,
169                 .schan_val2 = 10000,
170                 .expected = "0.0000000457763671875",
171         },
172         {
173                 .name = "small IIO_VAL_FRACTIONAL, 0 < scale < 1",
174                 .numerator = 6,
175                 .denominator = 6,
176                 .schan_scale_type = IIO_VAL_FRACTIONAL,
177                 .schan_val = 1,
178                 .schan_val2 = 3,
179                 .expected = "0.3333333333333333",
180         },
181         {
182                 .name = "small IIO_VAL_FRACTIONAL, -1 < scale < 0",
183                 .numerator = -6,
184                 .denominator = 6,
185                 .schan_scale_type = IIO_VAL_FRACTIONAL,
186                 .schan_val = 1,
187                 .schan_val2 = 3,
188                 .expected = "-0.3333333333333333",
189         },
190         {
191                 .name = "small IIO_VAL_FRACTIONAL, 0 < scale < 2",
192                 .numerator = 8,
193                 .denominator = 2,
194                 .schan_scale_type = IIO_VAL_FRACTIONAL,
195                 .schan_val = 1,
196                 .schan_val2 = 3,
197                 .expected = "1.3333333333333333",
198         },
199         {
200                 .name = "small IIO_VAL_FRACTIONAL, -2 < scale < 0",
201                 .numerator = -8,
202                 .denominator = 2,
203                 .schan_scale_type = IIO_VAL_FRACTIONAL,
204                 .schan_val = 1,
205                 .schan_val2 = 3,
206                 .expected = "-1.3333333333333333",
207         },
208         {
209                 .name = "small IIO_VAL_FRACTIONAL_LOG2, 760/32768 scaled by 15/22",
210                 .numerator = 760,
211                 .denominator = 32768,
212                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
213                 .schan_val = 15,
214                 .schan_val2 = 22,
215                 .expected = "0.000000082946",
216         },
217         {
218                 .name = "small IIO_VAL_FRACTIONAL_LOG2, 761/32768 scaled by 15/22",
219                 .numerator = 761,
220                 .denominator = 32768,
221                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
222                 .schan_val = 15,
223                 .schan_val2 = 22,
224                 .expected = "0.000000083055",
225         },
226         {
227                 .name = "small IIO_VAL_FRACTIONAL_LOG2, 0 < scale < 1",
228                 .numerator = 16,
229                 .denominator = 3,
230                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
231                 .schan_val = 1,
232                 .schan_val2 = 4,
233                 .expected = "0.3333333333333333",
234         },
235         {
236                 .name = "small IIO_VAL_FRACTIONAL_LOG2, -1 < scale < 0",
237                 .numerator = -16,
238                 .denominator = 3,
239                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
240                 .schan_val = 1,
241                 .schan_val2 = 4,
242                 .expected = "-0.3333333333333333",
243         },
244         {
245                 .name = "small IIO_VAL_FRACTIONAL_LOG2, 0 < scale < 2",
246                 .numerator = 8,
247                 .denominator = 3,
248                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
249                 .schan_val = 1,
250                 .schan_val2 = 1,
251                 .expected = "1.3333333333333333",
252         },
253         {
254                 .name = "small IIO_VAL_FRACTIONAL_LOG2, -2 < scale < 0",
255                 .numerator = -8,
256                 .denominator = 3,
257                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
258                 .schan_val = 1,
259                 .schan_val2 = 1,
260                 .expected = "-1.3333333333333333",
261         },
262         {
263                 .name = "small IIO_VAL_INT_PLUS_MICRO, positive",
264                 .numerator = 1,
265                 .denominator = 2,
266                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
267                 .schan_val = 5,
268                 .schan_val2 = 1234,
269                 .expected = "2.500617",
270         },
271         {
272                 .name = "small IIO_VAL_INT_PLUS_MICRO, negative",
273                 .numerator = -1,
274                 .denominator = 2,
275                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
276                 .schan_val = 5,
277                 .schan_val2 = 1234,
278                 .expected = "-2.500617",
279         },
280         /*
281          * INT_PLUS_{MICRO,NANO} positive/negative corner cases
282          */
283         {
284                 .name = "negative IIO_VAL_INT_PLUS_NANO, negative schan",
285                 .numerator = 1000000,
286                 .denominator = 8060,
287                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
288                 .schan_val = -10,
289                 .schan_val2 = 123456,
290                 .expected = "-1240.710106203",
291         },
292         {
293                 .name = "negative IIO_VAL_INT_PLUS_NANO, both negative",
294                 .numerator = -1000000,
295                 .denominator = 8060,
296                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
297                 .schan_val = -10,
298                 .schan_val2 = 123456,
299                 .expected = "1240.710106203",
300         },
301         {
302                 .name = "negative IIO_VAL_INT_PLUS_NANO, 3 negative",
303                 .numerator = -1000000,
304                 .denominator = -8060,
305                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
306                 .schan_val = -10,
307                 .schan_val2 = 123456,
308                 .expected = "-1240.710106203",
309         },
310         {
311                 .name = "negative IIO_VAL_INT_PLUS_NANO, 4 negative",
312                 .numerator = -1000000,
313                 .denominator = -8060,
314                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
315                 .schan_val = -10,
316                 .schan_val2 = -123456,
317                 .expected = "-1240.710106203",
318         },
319         {
320                 .name = "negative IIO_VAL_INT_PLUS_NANO, negative, *val = 0",
321                 .numerator = 1,
322                 .denominator = -10,
323                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
324                 .schan_val = 0,
325                 .schan_val2 = 123456789,
326                 .expected = "-0.012345678",
327         },
328         /*
329          * INT_PLUS_{MICRO,NANO} decimal part overflow
330          */
331         {
332                 .name = "decimal overflow IIO_VAL_INT_PLUS_NANO, positive",
333                 .numerator = 1000000,
334                 .denominator = 8060,
335                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
336                 .schan_val = 10,
337                 .schan_val2 = 123456789,
338                 .expected = "1256.01200856",
339         },
340         {
341                 .name = "decimal overflow IIO_VAL_INT_PLUS_NANO, negative",
342                 .numerator = -1000000,
343                 .denominator = 8060,
344                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
345                 .schan_val = 10,
346                 .schan_val2 = 123456789,
347                 .expected = "-1256.01200856",
348         },
349         {
350                 .name = "decimal overflow IIO_VAL_INT_PLUS_NANO, negative schan",
351                 .numerator = 1000000,
352                 .denominator = 8060,
353                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
354                 .schan_val = -10,
355                 .schan_val2 = 123456789,
356                 .expected = "-1256.01200856",
357         },
358         {
359                 .name = "decimal overflow IIO_VAL_INT_PLUS_MICRO, positive",
360                 .numerator = 1000000,
361                 .denominator = 8060,
362                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
363                 .schan_val = 10,
364                 .schan_val2 = 123456789,
365                 .expected = "16557.914267",
366         },
367         {
368                 .name = "decimal overflow IIO_VAL_INT_PLUS_MICRO, negative",
369                 .numerator = -1000000,
370                 .denominator = 8060,
371                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
372                 .schan_val = 10,
373                 .schan_val2 = 123456789,
374                 .expected = "-16557.914267",
375         },
376         {
377                 .name = "decimal overflow IIO_VAL_INT_PLUS_MICRO, negative schan",
378                 .numerator = 1000000,
379                 .denominator = 8060,
380                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
381                 .schan_val = -10,
382                 .schan_val2 = 123456789,
383                 .expected = "-16557.914267",
384         },
385         /*
386          * 32-bit overflow conditions
387          */
388         {
389                 .name = "overflow IIO_VAL_FRACTIONAL, positive",
390                 .numerator = 2,
391                 .denominator = 20,
392                 .schan_scale_type = IIO_VAL_FRACTIONAL,
393                 .schan_val = S32_MAX,
394                 .schan_val2 = 1,
395                 .expected = "214748364.7",
396         },
397         {
398                 .name = "overflow IIO_VAL_FRACTIONAL, negative",
399                 .numerator = -2,
400                 .denominator = 20,
401                 .schan_scale_type = IIO_VAL_FRACTIONAL,
402                 .schan_val = S32_MAX,
403                 .schan_val2 = 1,
404                 .expected = "-214748364.7",
405         },
406         {
407                 .name = "overflow IIO_VAL_FRACTIONAL_LOG2, positive",
408                 .numerator = S32_MAX,
409                 .denominator = 4096,
410                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
411                 .schan_val = 4096,
412                 .schan_val2 = 16,
413                 .expected = "32767.99998474121",
414         },
415         {
416                 .name = "overflow IIO_VAL_FRACTIONAL_LOG2, negative",
417                 .numerator = S32_MAX,
418                 .denominator = 4096,
419                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
420                 .schan_val = -4096,
421                 .schan_val2 = 16,
422                 .expected = "-32767.99998474121",
423         },
424         {
425                 .name = "overflow IIO_VAL_INT_PLUS_NANO, positive",
426                 .numerator = 2,
427                 .denominator = 20,
428                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
429                 .schan_val = 10,
430                 .schan_val2 = S32_MAX,
431                 .expected = "1.214748364",
432         },
433         {
434                 .name = "overflow IIO_VAL_INT_PLUS_NANO, negative",
435                 .numerator = -2,
436                 .denominator = 20,
437                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
438                 .schan_val = 10,
439                 .schan_val2 = S32_MAX,
440                 .expected = "-1.214748364",
441         },
442         {
443                 .name = "overflow IIO_VAL_INT_PLUS_NANO, negative schan",
444                 .numerator = 2,
445                 .denominator = 20,
446                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
447                 .schan_val = -10,
448                 .schan_val2 = S32_MAX,
449                 .expected = "-1.214748364",
450         },
451         {
452                 .name = "overflow IIO_VAL_INT_PLUS_MICRO, positive",
453                 .numerator = 2,
454                 .denominator = 20,
455                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
456                 .schan_val = 10,
457                 .schan_val2 = S32_MAX,
458                 .expected = "215.748364",
459         },
460         {
461                 .name = "overflow IIO_VAL_INT_PLUS_MICRO, negative",
462                 .numerator = -2,
463                 .denominator = 20,
464                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
465                 .schan_val = 10,
466                 .schan_val2 = S32_MAX,
467                 .expected = "-215.748364",
468         },
469         {
470                 .name = "overflow IIO_VAL_INT_PLUS_MICRO, negative schan",
471                 .numerator = 2,
472                 .denominator = 20,
473                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
474                 .schan_val = -10,
475                 .schan_val2 = S32_MAX,
476                 .expected = "-215.748364",
477         },
478 };
479
480 static const struct rescale_tc_data offset_cases[] = {
481         /*
482          * Typical use cases
483          */
484         {
485                 .name = "typical IIO_VAL_INT, positive",
486                 .offset = 1234,
487                 .schan_scale_type = IIO_VAL_INT,
488                 .schan_val = 123,
489                 .schan_val2 = 0,
490                 .schan_off = 14,
491                 .expected_off = "24", /* 23.872 */
492         },
493         {
494                 .name = "typical IIO_VAL_INT, negative",
495                 .offset = -1234,
496                 .schan_scale_type = IIO_VAL_INT,
497                 .schan_val = 12,
498                 .schan_val2 = 0,
499                 .schan_off = 14,
500                 .expected_off = "-88", /* -88.83333333333333 */
501         },
502         {
503                 .name = "typical IIO_VAL_FRACTIONAL, positive",
504                 .offset = 1234,
505                 .schan_scale_type = IIO_VAL_FRACTIONAL,
506                 .schan_val = 12,
507                 .schan_val2 = 34,
508                 .schan_off = 14,
509                 .expected_off = "3510", /* 3510.333333333333 */
510         },
511         {
512                 .name = "typical IIO_VAL_FRACTIONAL, negative",
513                 .offset = -1234,
514                 .schan_scale_type = IIO_VAL_FRACTIONAL,
515                 .schan_val = 12,
516                 .schan_val2 = 34,
517                 .schan_off = 14,
518                 .expected_off = "-3482", /* -3482.333333333333 */
519         },
520         {
521                 .name = "typical IIO_VAL_FRACTIONAL_LOG2, positive",
522                 .offset = 1234,
523                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
524                 .schan_val = 12,
525                 .schan_val2 = 16,
526                 .schan_off = 14,
527                 .expected_off = "6739299", /* 6739299.333333333 */
528         },
529         {
530                 .name = "typical IIO_VAL_FRACTIONAL_LOG2, negative",
531                 .offset = -1234,
532                 .schan_scale_type = IIO_VAL_FRACTIONAL_LOG2,
533                 .schan_val = 12,
534                 .schan_val2 = 16,
535                 .schan_off = 14,
536                 .expected_off = "-6739271", /* -6739271.333333333 */
537         },
538         {
539                 .name = "typical IIO_VAL_INT_PLUS_NANO, positive",
540                 .offset = 1234,
541                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
542                 .schan_val = 10,
543                 .schan_val2 = 123456789,
544                 .schan_off = 14,
545                 .expected_off = "135", /* 135.8951219647469 */
546         },
547         {
548                 .name = "typical IIO_VAL_INT_PLUS_NANO, negative",
549                 .offset = -1234,
550                 .schan_scale_type = IIO_VAL_INT_PLUS_NANO,
551                 .schan_val = 10,
552                 .schan_val2 = 123456789,
553                 .schan_off = 14,
554                 .expected_off = "-107", /* -107.89512196474689 */
555         },
556         {
557                 .name = "typical IIO_VAL_INT_PLUS_MICRO, positive",
558                 .offset = 1234,
559                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
560                 .schan_val = 10,
561                 .schan_val2 = 123456789,
562                 .schan_off = 14,
563                 .expected_off = "23", /* 23.246438560723952 */
564         },
565         {
566                 .name = "typical IIO_VAL_INT_PLUS_MICRO, negative",
567                 .offset = -12345,
568                 .schan_scale_type = IIO_VAL_INT_PLUS_MICRO,
569                 .schan_val = 10,
570                 .schan_val2 = 123456789,
571                 .schan_off = 14,
572                 .expected_off = "-78", /* -78.50185091745313 */
573         },
574 };
575
576 static void case_to_desc(const struct rescale_tc_data *t, char *desc)
577 {
578         strcpy(desc, t->name);
579 }
580
581 KUNIT_ARRAY_PARAM(iio_rescale_scale, scale_cases, case_to_desc);
582 KUNIT_ARRAY_PARAM(iio_rescale_offset, offset_cases, case_to_desc);
583
584 /**
585  * iio_str_to_nano() - Parse a fixed-point string to get an
586  *                      IIO_VAL_INT_PLUS_NANO value
587  * @str: The string to parse
588  * @nano: The number as an integer
589  *
590  * Returns 0 on success, or a negative error code if the string cound not be
591  * parsed.
592  */
593 static int iio_str_to_nano(const char *str, s64 *nano)
594 {
595         int tmp, tmp2;
596         int ret = 0;
597
598         /*
599          * iio_str_to_fixpoint() uses 10^8 here instead of 10^9 as fract_mult is
600          * the multiplier for the first decimal place.
601          */
602         ret = iio_str_to_fixpoint(str, 100000000, &tmp, &tmp2);
603         if (ret < 0)
604                 return ret;
605
606         if (tmp < 0)
607                 tmp2 *= -1;
608
609         *nano = (s64)tmp * 1000000000UL + tmp2;
610
611         return ret;
612 }
613
614 /**
615  * iio_test_relative_error_ppm() - Compute relative error (in parts-per-million)
616  *                                 between two fixed-point strings
617  * @real_str: The real value as a string
618  * @exp_str: The expected value as a string
619  *
620  * Returns a negative error code if the strings cound not be parsed, or the
621  * relative error in parts-per-million.
622  */
623 static int iio_test_relative_error_ppm(const char *real_str, const char *exp_str)
624 {
625         s64 real, exp, err;
626         int ret;
627
628         ret = iio_str_to_nano(real_str, &real);
629         if (ret < 0)
630                 return ret;
631
632         ret = iio_str_to_nano(exp_str, &exp);
633         if (ret < 0)
634                 return ret;
635
636         if (!exp) {
637                 pr_err("Expected value is null, relative error is undefined\n");
638                 return -EINVAL;
639         }
640
641         err = 1000000UL * abs(exp - real);
642
643         return (int)div64_u64(err, abs(exp));
644 }
645
646 static void iio_rescale_test_scale(struct kunit *test)
647 {
648         struct rescale_tc_data *t = (struct rescale_tc_data *)test->param_value;
649         char *buff = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL);
650         struct rescale rescale;
651         int values[2];
652         int rel_ppm;
653         int ret;
654
655         rescale.numerator = t->numerator;
656         rescale.denominator = t->denominator;
657         rescale.offset = t->offset;
658         values[0] = t->schan_val;
659         values[1] = t->schan_val2;
660
661         ret = rescale_process_scale(&rescale, t->schan_scale_type,
662                                     &values[0], &values[1]);
663
664         ret = iio_format_value(buff, ret, 2, values);
665         KUNIT_EXPECT_EQ(test, (int)strlen(buff), ret);
666
667         rel_ppm = iio_test_relative_error_ppm(buff, t->expected);
668         KUNIT_EXPECT_GE_MSG(test, rel_ppm, 0, "failed to compute ppm\n");
669
670         KUNIT_EXPECT_EQ_MSG(test, rel_ppm, 0,
671                             "\t    real=%s"
672                             "\texpected=%s\n",
673                             buff, t->expected);
674 }
675
676 static void iio_rescale_test_offset(struct kunit *test)
677 {
678         struct rescale_tc_data *t = (struct rescale_tc_data *)test->param_value;
679         char *buff_off = kunit_kmalloc(test, PAGE_SIZE, GFP_KERNEL);
680         struct rescale rescale;
681         int values[2];
682         int ret;
683
684         rescale.numerator = t->numerator;
685         rescale.denominator = t->denominator;
686         rescale.offset = t->offset;
687         values[0] = t->schan_val;
688         values[1] = t->schan_val2;
689
690         ret = rescale_process_offset(&rescale, t->schan_scale_type,
691                                      t->schan_val, t->schan_val2, t->schan_off,
692                                      &values[0], &values[1]);
693
694         ret = iio_format_value(buff_off, ret, 2, values);
695         KUNIT_EXPECT_EQ(test, (int)strlen(buff_off), ret);
696
697         KUNIT_EXPECT_STREQ(test, strim(buff_off), t->expected_off);
698 }
699
700 static struct kunit_case iio_rescale_test_cases[] = {
701         KUNIT_CASE_PARAM(iio_rescale_test_scale, iio_rescale_scale_gen_params),
702         KUNIT_CASE_PARAM(iio_rescale_test_offset, iio_rescale_offset_gen_params),
703         {}
704 };
705
706 static struct kunit_suite iio_rescale_test_suite = {
707         .name = "iio-rescale",
708         .test_cases = iio_rescale_test_cases,
709 };
710 kunit_test_suite(iio_rescale_test_suite);
711
712 MODULE_AUTHOR("Liam Beguin <liambeguin@gmail.com>");
713 MODULE_DESCRIPTION("Test IIO rescale conversion functions");
714 MODULE_LICENSE("GPL v2");
715 MODULE_IMPORT_NS(IIO_RESCALE);