packing_test.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474
  1. // SPDX-License-Identifier: GPL-2.0
  2. /* Copyright (c) 2024, Vladimir Oltean <olteanv@gmail.com>
  3. * Copyright (c) 2024, Intel Corporation.
  4. */
  5. #include <kunit/test.h>
  6. #include <linux/packing.h>
  7. struct packing_test_case {
  8. const char *desc;
  9. const u8 *pbuf;
  10. size_t pbuf_size;
  11. u64 uval;
  12. size_t start_bit;
  13. size_t end_bit;
  14. u8 quirks;
  15. };
  16. #define NO_QUIRKS 0
  17. /**
  18. * PBUF - Initialize .pbuf and .pbuf_size
  19. * @array: elements of constant physical buffer
  20. *
  21. * Initializes the .pbuf and .pbuf_size fields of a struct packing_test_case
  22. * with a constant array of the specified elements.
  23. */
  24. #define PBUF(array...) \
  25. .pbuf = (const u8[]){ array }, \
  26. .pbuf_size = sizeof((const u8 []){ array })
  27. static const struct packing_test_case cases[] = {
  28. /* These tests pack and unpack a magic 64-bit value
  29. * (0xcafedeadbeefcafe) at a fixed logical offset (32) within an
  30. * otherwise zero array of 128 bits (16 bytes). They test all possible
  31. * bit layouts of the 128 bit buffer.
  32. */
  33. {
  34. .desc = "no quirks, 16 bytes",
  35. PBUF(0x00, 0x00, 0x00, 0x00, 0xca, 0xfe, 0xde, 0xad,
  36. 0xbe, 0xef, 0xca, 0xfe, 0x00, 0x00, 0x00, 0x00),
  37. .uval = 0xcafedeadbeefcafe,
  38. .start_bit = 95,
  39. .end_bit = 32,
  40. .quirks = NO_QUIRKS,
  41. },
  42. {
  43. .desc = "lsw32 first, 16 bytes",
  44. PBUF(0x00, 0x00, 0x00, 0x00, 0xbe, 0xef, 0xca, 0xfe,
  45. 0xca, 0xfe, 0xde, 0xad, 0x00, 0x00, 0x00, 0x00),
  46. .uval = 0xcafedeadbeefcafe,
  47. .start_bit = 95,
  48. .end_bit = 32,
  49. .quirks = QUIRK_LSW32_IS_FIRST,
  50. },
  51. {
  52. .desc = "little endian words, 16 bytes",
  53. PBUF(0x00, 0x00, 0x00, 0x00, 0xad, 0xde, 0xfe, 0xca,
  54. 0xfe, 0xca, 0xef, 0xbe, 0x00, 0x00, 0x00, 0x00),
  55. .uval = 0xcafedeadbeefcafe,
  56. .start_bit = 95,
  57. .end_bit = 32,
  58. .quirks = QUIRK_LITTLE_ENDIAN,
  59. },
  60. {
  61. .desc = "lsw32 first + little endian words, 16 bytes",
  62. PBUF(0x00, 0x00, 0x00, 0x00, 0xfe, 0xca, 0xef, 0xbe,
  63. 0xad, 0xde, 0xfe, 0xca, 0x00, 0x00, 0x00, 0x00),
  64. .uval = 0xcafedeadbeefcafe,
  65. .start_bit = 95,
  66. .end_bit = 32,
  67. .quirks = QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  68. },
  69. {
  70. .desc = "msb right, 16 bytes",
  71. PBUF(0x00, 0x00, 0x00, 0x00, 0x53, 0x7f, 0x7b, 0xb5,
  72. 0x7d, 0xf7, 0x53, 0x7f, 0x00, 0x00, 0x00, 0x00),
  73. .uval = 0xcafedeadbeefcafe,
  74. .start_bit = 95,
  75. .end_bit = 32,
  76. .quirks = QUIRK_MSB_ON_THE_RIGHT,
  77. },
  78. {
  79. .desc = "msb right + lsw32 first, 16 bytes",
  80. PBUF(0x00, 0x00, 0x00, 0x00, 0x7d, 0xf7, 0x53, 0x7f,
  81. 0x53, 0x7f, 0x7b, 0xb5, 0x00, 0x00, 0x00, 0x00),
  82. .uval = 0xcafedeadbeefcafe,
  83. .start_bit = 95,
  84. .end_bit = 32,
  85. .quirks = QUIRK_MSB_ON_THE_RIGHT | QUIRK_LSW32_IS_FIRST,
  86. },
  87. {
  88. .desc = "msb right + little endian words, 16 bytes",
  89. PBUF(0x00, 0x00, 0x00, 0x00, 0xb5, 0x7b, 0x7f, 0x53,
  90. 0x7f, 0x53, 0xf7, 0x7d, 0x00, 0x00, 0x00, 0x00),
  91. .uval = 0xcafedeadbeefcafe,
  92. .start_bit = 95,
  93. .end_bit = 32,
  94. .quirks = QUIRK_MSB_ON_THE_RIGHT | QUIRK_LITTLE_ENDIAN,
  95. },
  96. {
  97. .desc = "msb right + lsw32 first + little endian words, 16 bytes",
  98. PBUF(0x00, 0x00, 0x00, 0x00, 0x7f, 0x53, 0xf7, 0x7d,
  99. 0xb5, 0x7b, 0x7f, 0x53, 0x00, 0x00, 0x00, 0x00),
  100. .uval = 0xcafedeadbeefcafe,
  101. .start_bit = 95,
  102. .end_bit = 32,
  103. .quirks = QUIRK_MSB_ON_THE_RIGHT | QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  104. },
  105. /* These tests pack and unpack a magic 64-bit value
  106. * (0xcafedeadbeefcafe) at a fixed logical offset (32) within an
  107. * otherwise zero array of varying size from 18 bytes to 24 bytes.
  108. */
  109. {
  110. .desc = "no quirks, 18 bytes",
  111. PBUF(0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xca, 0xfe,
  112. 0xde, 0xad, 0xbe, 0xef, 0xca, 0xfe, 0x00, 0x00,
  113. 0x00, 0x00),
  114. .uval = 0xcafedeadbeefcafe,
  115. .start_bit = 95,
  116. .end_bit = 32,
  117. .quirks = NO_QUIRKS,
  118. },
  119. {
  120. .desc = "no quirks, 19 bytes",
  121. PBUF(0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xca,
  122. 0xfe, 0xde, 0xad, 0xbe, 0xef, 0xca, 0xfe, 0x00,
  123. 0x00, 0x00, 0x00),
  124. .uval = 0xcafedeadbeefcafe,
  125. .start_bit = 95,
  126. .end_bit = 32,
  127. .quirks = NO_QUIRKS,
  128. },
  129. {
  130. .desc = "no quirks, 20 bytes",
  131. PBUF(0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  132. 0xca, 0xfe, 0xde, 0xad, 0xbe, 0xef, 0xca, 0xfe,
  133. 0x00, 0x00, 0x00, 0x00),
  134. .uval = 0xcafedeadbeefcafe,
  135. .start_bit = 95,
  136. .end_bit = 32,
  137. .quirks = NO_QUIRKS,
  138. },
  139. {
  140. .desc = "no quirks, 22 bytes",
  141. PBUF(0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  142. 0x00, 0x00, 0xca, 0xfe, 0xde, 0xad, 0xbe, 0xef,
  143. 0xca, 0xfe, 0x00, 0x00, 0x00, 0x00),
  144. .uval = 0xcafedeadbeefcafe,
  145. .start_bit = 95,
  146. .end_bit = 32,
  147. .quirks = NO_QUIRKS,
  148. },
  149. {
  150. .desc = "no quirks, 24 bytes",
  151. PBUF(0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  152. 0x00, 0x00, 0x00, 0x00, 0xca, 0xfe, 0xde, 0xad,
  153. 0xbe, 0xef, 0xca, 0xfe, 0x00, 0x00, 0x00, 0x00),
  154. .uval = 0xcafedeadbeefcafe,
  155. .start_bit = 95,
  156. .end_bit = 32,
  157. .quirks = NO_QUIRKS,
  158. },
  159. {
  160. .desc = "lsw32 first + little endian words, 18 bytes",
  161. PBUF(0x00, 0x00, 0x00, 0x00, 0xfe, 0xca, 0xef, 0xbe,
  162. 0xad, 0xde, 0xfe, 0xca, 0x00, 0x00, 0x00, 0x00,
  163. 0x00, 0x00),
  164. .uval = 0xcafedeadbeefcafe,
  165. .start_bit = 95,
  166. .end_bit = 32,
  167. .quirks = QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  168. },
  169. {
  170. .desc = "lsw32 first + little endian words, 19 bytes",
  171. PBUF(0x00, 0x00, 0x00, 0x00, 0xfe, 0xca, 0xef, 0xbe,
  172. 0xad, 0xde, 0xfe, 0xca, 0x00, 0x00, 0x00, 0x00,
  173. 0x00, 0x00, 0x00),
  174. .uval = 0xcafedeadbeefcafe,
  175. .start_bit = 95,
  176. .end_bit = 32,
  177. .quirks = QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  178. },
  179. {
  180. .desc = "lsw32 first + little endian words, 20 bytes",
  181. PBUF(0x00, 0x00, 0x00, 0x00, 0xfe, 0xca, 0xef, 0xbe,
  182. 0xad, 0xde, 0xfe, 0xca, 0x00, 0x00, 0x00, 0x00,
  183. 0x00, 0x00, 0x00, 0x00),
  184. .uval = 0xcafedeadbeefcafe,
  185. .start_bit = 95,
  186. .end_bit = 32,
  187. .quirks = QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  188. },
  189. {
  190. .desc = "lsw32 first + little endian words, 22 bytes",
  191. PBUF(0x00, 0x00, 0x00, 0x00, 0xfe, 0xca, 0xef, 0xbe,
  192. 0xad, 0xde, 0xfe, 0xca, 0x00, 0x00, 0x00, 0x00,
  193. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00),
  194. .uval = 0xcafedeadbeefcafe,
  195. .start_bit = 95,
  196. .end_bit = 32,
  197. .quirks = QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  198. },
  199. {
  200. .desc = "lsw32 first + little endian words, 24 bytes",
  201. PBUF(0x00, 0x00, 0x00, 0x00, 0xfe, 0xca, 0xef, 0xbe,
  202. 0xad, 0xde, 0xfe, 0xca, 0x00, 0x00, 0x00, 0x00,
  203. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00),
  204. .uval = 0xcafedeadbeefcafe,
  205. .start_bit = 95,
  206. .end_bit = 32,
  207. .quirks = QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  208. },
  209. /* These tests pack and unpack a magic 64-bit value
  210. * (0x1122334455667788) at an odd starting bit (43) within an
  211. * otherwise zero array of 128 bits (16 bytes). They test all possible
  212. * bit layouts of the 128 bit buffer.
  213. */
  214. {
  215. .desc = "no quirks, 16 bytes, non-aligned",
  216. PBUF(0x00, 0x00, 0x00, 0x89, 0x11, 0x9a, 0x22, 0xab,
  217. 0x33, 0xbc, 0x40, 0x00, 0x00, 0x00, 0x00, 0x00),
  218. .uval = 0x1122334455667788,
  219. .start_bit = 106,
  220. .end_bit = 43,
  221. .quirks = NO_QUIRKS,
  222. },
  223. {
  224. .desc = "lsw32 first, 16 bytes, non-aligned",
  225. PBUF(0x00, 0x00, 0x00, 0x00, 0x33, 0xbc, 0x40, 0x00,
  226. 0x11, 0x9a, 0x22, 0xab, 0x00, 0x00, 0x00, 0x89),
  227. .uval = 0x1122334455667788,
  228. .start_bit = 106,
  229. .end_bit = 43,
  230. .quirks = QUIRK_LSW32_IS_FIRST,
  231. },
  232. {
  233. .desc = "little endian words, 16 bytes, non-aligned",
  234. PBUF(0x89, 0x00, 0x00, 0x00, 0xab, 0x22, 0x9a, 0x11,
  235. 0x00, 0x40, 0xbc, 0x33, 0x00, 0x00, 0x00, 0x00),
  236. .uval = 0x1122334455667788,
  237. .start_bit = 106,
  238. .end_bit = 43,
  239. .quirks = QUIRK_LITTLE_ENDIAN,
  240. },
  241. {
  242. .desc = "lsw32 first + little endian words, 16 bytes, non-aligned",
  243. PBUF(0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0xbc, 0x33,
  244. 0xab, 0x22, 0x9a, 0x11, 0x89, 0x00, 0x00, 0x00),
  245. .uval = 0x1122334455667788,
  246. .start_bit = 106,
  247. .end_bit = 43,
  248. .quirks = QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  249. },
  250. {
  251. .desc = "msb right, 16 bytes, non-aligned",
  252. PBUF(0x00, 0x00, 0x00, 0x91, 0x88, 0x59, 0x44, 0xd5,
  253. 0xcc, 0x3d, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00),
  254. .uval = 0x1122334455667788,
  255. .start_bit = 106,
  256. .end_bit = 43,
  257. .quirks = QUIRK_MSB_ON_THE_RIGHT,
  258. },
  259. {
  260. .desc = "msb right + lsw32 first, 16 bytes, non-aligned",
  261. PBUF(0x00, 0x00, 0x00, 0x00, 0xcc, 0x3d, 0x02, 0x00,
  262. 0x88, 0x59, 0x44, 0xd5, 0x00, 0x00, 0x00, 0x91),
  263. .uval = 0x1122334455667788,
  264. .start_bit = 106,
  265. .end_bit = 43,
  266. .quirks = QUIRK_MSB_ON_THE_RIGHT | QUIRK_LSW32_IS_FIRST,
  267. },
  268. {
  269. .desc = "msb right + little endian words, 16 bytes, non-aligned",
  270. PBUF(0x91, 0x00, 0x00, 0x00, 0xd5, 0x44, 0x59, 0x88,
  271. 0x00, 0x02, 0x3d, 0xcc, 0x00, 0x00, 0x00, 0x00),
  272. .uval = 0x1122334455667788,
  273. .start_bit = 106,
  274. .end_bit = 43,
  275. .quirks = QUIRK_MSB_ON_THE_RIGHT | QUIRK_LITTLE_ENDIAN,
  276. },
  277. {
  278. .desc = "msb right + lsw32 first + little endian words, 16 bytes, non-aligned",
  279. PBUF(0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x3d, 0xcc,
  280. 0xd5, 0x44, 0x59, 0x88, 0x91, 0x00, 0x00, 0x00),
  281. .uval = 0x1122334455667788,
  282. .start_bit = 106,
  283. .end_bit = 43,
  284. .quirks = QUIRK_MSB_ON_THE_RIGHT | QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  285. },
  286. /* These tests pack and unpack a u64 with all bits set
  287. * (0xffffffffffffffff) at an odd starting bit (43) within an
  288. * otherwise zero array of 128 bits (16 bytes). They test all possible
  289. * bit layouts of the 128 bit buffer.
  290. */
  291. {
  292. .desc = "no quirks, 16 bytes, non-aligned, 0xff",
  293. PBUF(0x00, 0x00, 0x07, 0xff, 0xff, 0xff, 0xff, 0xff,
  294. 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00),
  295. .uval = 0xffffffffffffffff,
  296. .start_bit = 106,
  297. .end_bit = 43,
  298. .quirks = NO_QUIRKS,
  299. },
  300. {
  301. .desc = "lsw32 first, 16 bytes, non-aligned, 0xff",
  302. PBUF(0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xf8, 0x00,
  303. 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x07, 0xff),
  304. .uval = 0xffffffffffffffff,
  305. .start_bit = 106,
  306. .end_bit = 43,
  307. .quirks = QUIRK_LSW32_IS_FIRST,
  308. },
  309. {
  310. .desc = "little endian words, 16 bytes, non-aligned, 0xff",
  311. PBUF(0xff, 0x07, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff,
  312. 0x00, 0xf8, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00),
  313. .uval = 0xffffffffffffffff,
  314. .start_bit = 106,
  315. .end_bit = 43,
  316. .quirks = QUIRK_LITTLE_ENDIAN,
  317. },
  318. {
  319. .desc = "lsw32 first + little endian words, 16 bytes, non-aligned, 0xff",
  320. PBUF(0x00, 0x00, 0x00, 0x00, 0x00, 0xf8, 0xff, 0xff,
  321. 0xff, 0xff, 0xff, 0xff, 0xff, 0x07, 0x00, 0x00),
  322. .uval = 0xffffffffffffffff,
  323. .start_bit = 106,
  324. .end_bit = 43,
  325. .quirks = QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  326. },
  327. {
  328. .desc = "msb right, 16 bytes, non-aligned, 0xff",
  329. PBUF(0x00, 0x00, 0xe0, 0xff, 0xff, 0xff, 0xff, 0xff,
  330. 0xff, 0xff, 0x1f, 0x00, 0x00, 0x00, 0x00, 0x00),
  331. .uval = 0xffffffffffffffff,
  332. .start_bit = 106,
  333. .end_bit = 43,
  334. .quirks = QUIRK_MSB_ON_THE_RIGHT,
  335. },
  336. {
  337. .desc = "msb right + lsw32 first, 16 bytes, non-aligned, 0xff",
  338. PBUF(0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0x1f, 0x00,
  339. 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0xe0, 0xff),
  340. .uval = 0xffffffffffffffff,
  341. .start_bit = 106,
  342. .end_bit = 43,
  343. .quirks = QUIRK_MSB_ON_THE_RIGHT | QUIRK_LSW32_IS_FIRST,
  344. },
  345. {
  346. .desc = "msb right + little endian words, 16 bytes, non-aligned, 0xff",
  347. PBUF(0xff, 0xe0, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff,
  348. 0x00, 0x1f, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00),
  349. .uval = 0xffffffffffffffff,
  350. .start_bit = 106,
  351. .end_bit = 43,
  352. .quirks = QUIRK_MSB_ON_THE_RIGHT | QUIRK_LITTLE_ENDIAN,
  353. },
  354. {
  355. .desc = "msb right + lsw32 first + little endian words, 16 bytes, non-aligned, 0xff",
  356. PBUF(0x00, 0x00, 0x00, 0x00, 0x00, 0x1f, 0xff, 0xff,
  357. 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00),
  358. .uval = 0xffffffffffffffff,
  359. .start_bit = 106,
  360. .end_bit = 43,
  361. .quirks = QUIRK_MSB_ON_THE_RIGHT | QUIRK_LSW32_IS_FIRST | QUIRK_LITTLE_ENDIAN,
  362. },
  363. };
  364. KUNIT_ARRAY_PARAM_DESC(packing, cases, desc);
  365. static void packing_test_pack(struct kunit *test)
  366. {
  367. const struct packing_test_case *params = test->param_value;
  368. u8 *pbuf;
  369. int err;
  370. pbuf = kunit_kzalloc(test, params->pbuf_size, GFP_KERNEL);
  371. KUNIT_ASSERT_NOT_NULL(test, pbuf);
  372. err = pack(pbuf, params->uval, params->start_bit, params->end_bit,
  373. params->pbuf_size, params->quirks);
  374. KUNIT_EXPECT_EQ_MSG(test, err, 0, "pack() returned %pe\n", ERR_PTR(err));
  375. KUNIT_EXPECT_MEMEQ(test, pbuf, params->pbuf, params->pbuf_size);
  376. }
  377. static void packing_test_unpack(struct kunit *test)
  378. {
  379. const struct packing_test_case *params = test->param_value;
  380. u64 uval;
  381. int err;
  382. err = unpack(params->pbuf, &uval, params->start_bit, params->end_bit,
  383. params->pbuf_size, params->quirks);
  384. KUNIT_EXPECT_EQ_MSG(test, err, 0, "unpack() returned %pe\n", ERR_PTR(err));
  385. KUNIT_EXPECT_EQ(test, uval, params->uval);
  386. }
  387. #define PACKED_BUF_SIZE 8
  388. typedef struct __packed { u8 buf[PACKED_BUF_SIZE]; } packed_buf_t;
  389. struct test_data {
  390. u32 field3;
  391. u16 field2;
  392. u16 field4;
  393. u16 field6;
  394. u8 field1;
  395. u8 field5;
  396. };
  397. static const struct packed_field_u8 test_fields[] = {
  398. PACKED_FIELD(63, 61, struct test_data, field1),
  399. PACKED_FIELD(60, 52, struct test_data, field2),
  400. PACKED_FIELD(51, 28, struct test_data, field3),
  401. PACKED_FIELD(27, 14, struct test_data, field4),
  402. PACKED_FIELD(13, 9, struct test_data, field5),
  403. PACKED_FIELD(8, 0, struct test_data, field6),
  404. };
  405. static void packing_test_pack_fields(struct kunit *test)
  406. {
  407. const struct test_data data = {
  408. .field1 = 0x2,
  409. .field2 = 0x100,
  410. .field3 = 0xF00050,
  411. .field4 = 0x7D3,
  412. .field5 = 0x9,
  413. .field6 = 0x10B,
  414. };
  415. packed_buf_t expect = {
  416. .buf = { 0x50, 0x0F, 0x00, 0x05, 0x01, 0xF4, 0xD3, 0x0B },
  417. };
  418. packed_buf_t buf = {};
  419. pack_fields(&buf, sizeof(buf), &data, test_fields, 0);
  420. KUNIT_EXPECT_MEMEQ(test, &expect, &buf, sizeof(buf));
  421. }
  422. static void packing_test_unpack_fields(struct kunit *test)
  423. {
  424. const packed_buf_t buf = {
  425. .buf = { 0x17, 0x28, 0x10, 0x19, 0x3D, 0xA9, 0x07, 0x9C },
  426. };
  427. struct test_data data = {};
  428. unpack_fields(&buf, sizeof(buf), &data, test_fields, 0);
  429. KUNIT_EXPECT_EQ(test, 0, data.field1);
  430. KUNIT_EXPECT_EQ(test, 0x172, data.field2);
  431. KUNIT_EXPECT_EQ(test, 0x810193, data.field3);
  432. KUNIT_EXPECT_EQ(test, 0x36A4, data.field4);
  433. KUNIT_EXPECT_EQ(test, 0x3, data.field5);
  434. KUNIT_EXPECT_EQ(test, 0x19C, data.field6);
  435. }
  436. static struct kunit_case packing_test_cases[] = {
  437. KUNIT_CASE_PARAM(packing_test_pack, packing_gen_params),
  438. KUNIT_CASE_PARAM(packing_test_unpack, packing_gen_params),
  439. KUNIT_CASE(packing_test_pack_fields),
  440. KUNIT_CASE(packing_test_unpack_fields),
  441. {},
  442. };
  443. static struct kunit_suite packing_test_suite = {
  444. .name = "packing",
  445. .test_cases = packing_test_cases,
  446. };
  447. kunit_test_suite(packing_test_suite);
  448. MODULE_LICENSE("GPL");
  449. MODULE_DESCRIPTION("KUnit tests for packing library");