cb_bitopt_test.cpp 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479
  1. /*
  2. * SPDX-License-Identifier: Apache-2.0
  3. *
  4. * Change Logs:
  5. * Date Author Notes
  6. * 2023-10-05 tyx first implementation
  7. */
  8. #include <stdint.h>
  9. #include <gtest/gtest.h>
  10. #include "cb_bitopt.h"
  11. TEST(testCase, cb_bitopt_setbit_test01)
  12. {
  13. uint32_t v;
  14. uint32_t one = 0x1U;
  15. for (unsigned int i = 0; i < 32U; i++)
  16. {
  17. v = 0U;
  18. cb_setbit(&v, i);
  19. EXPECT_EQ(v, one << i);
  20. }
  21. }
  22. TEST(testCase, cb_bitopt_setbit_test02)
  23. {
  24. uint32_t v1 = 0U, v2 = 0U;
  25. uint32_t one = 0x1U;
  26. for (unsigned int i = 0; i < 32U; i++)
  27. {
  28. cb_setbit(&v1, i);
  29. v2 |= one << i;
  30. EXPECT_EQ(v1, v2);
  31. }
  32. }
  33. TEST(testCase, cb_bitopt_clearbit_test01)
  34. {
  35. uint32_t v1, v2;
  36. uint32_t zero = 0x0U, one = 0x1U;
  37. for (unsigned int i = 0; i < 32U; i++)
  38. {
  39. v1 = ~zero;
  40. cb_clearbit(&v1, i);
  41. v2 = (~zero) & (~(one << i));
  42. EXPECT_EQ(v1, v2);
  43. }
  44. }
  45. TEST(testCase, cb_bitopt_clearbit_test02)
  46. {
  47. uint32_t v1;
  48. uint32_t v2;
  49. uint32_t zero = 0x0U, one = 0x1U;
  50. v1 = ~zero;
  51. v2 = ~zero;
  52. for (unsigned int i = 0; i < 32U; i++)
  53. {
  54. cb_clearbit(&v1, i);
  55. v2 = v2 & (~(one << i));
  56. EXPECT_EQ(v1, v2);
  57. }
  58. }
  59. TEST(testCase, cb_bitopt_testbit_test01)
  60. {
  61. uint32_t v;
  62. uint32_t zero = 0x0U, one = 0x1U;
  63. for (unsigned int i = 0; i < 32U; i++)
  64. {
  65. v = one << i;
  66. EXPECT_TRUE(cb_testbit(&v, i));
  67. v = (~zero) & (~(one << i));
  68. EXPECT_FALSE(cb_testbit(&v, i));
  69. }
  70. }
  71. TEST(testCase, cb_bitopt_ffs32_test01)
  72. {
  73. uint32_t v;
  74. uint32_t zero = 0x0U, one = 0x1U;
  75. EXPECT_EQ(cb_ffs32(0x1), 0);
  76. EXPECT_EQ(cb_ffs32(0x2), 1);
  77. EXPECT_EQ(cb_ffs32(0x80000000), 31);
  78. EXPECT_EQ(cb_ffs32(0), 0);
  79. for (unsigned int i = 0; i < 32U; i++)
  80. {
  81. v = one << i;
  82. EXPECT_EQ(cb_ffs32(v), i);
  83. v = (~zero) << i;
  84. EXPECT_EQ(cb_ffs32(v), i);
  85. }
  86. }
  87. TEST(testCase, cb_bitopt_ffs64_test01)
  88. {
  89. uint64_t v;
  90. EXPECT_EQ(cb_ffs64(0x1ULL), 0);
  91. EXPECT_EQ(cb_ffs64(0x2ULL), 1);
  92. EXPECT_EQ(cb_ffs64(0x80000000ULL), 31);
  93. EXPECT_EQ(cb_ffs64(0x8000000000000000ULL), 63);
  94. EXPECT_EQ(cb_ffs64(0), 0);
  95. for (unsigned int i = 0; i < 64U; i++)
  96. {
  97. v = 0x1ULL << i;
  98. EXPECT_EQ(cb_ffs64(v), i);
  99. v = 0xFFFFFFFFFFFFFFFFULL << i;
  100. EXPECT_EQ(cb_ffs64(v), i);
  101. }
  102. }
  103. TEST(testCase, cb_bitopt_ffs_test01)
  104. {
  105. unsigned long v;
  106. unsigned long one = 1UL;
  107. unsigned long zero = 0UL;
  108. EXPECT_EQ(cb_ffs(0), 0);
  109. for (unsigned long i = 0; i < sizeof(unsigned long) * 8UL; i++)
  110. {
  111. v = one << i;
  112. EXPECT_EQ(cb_ffs(v), i);
  113. v = (~zero) << i;
  114. EXPECT_EQ(cb_ffs(v), i);
  115. }
  116. }
  117. TEST(testCase, cb_bitopt_ffz32_test01)
  118. {
  119. uint32_t v;
  120. uint32_t zero = 0x0U, one = 0x1U;
  121. EXPECT_EQ(cb_ffz32(zero), 0);
  122. EXPECT_EQ(cb_ffz32(one), 1);
  123. EXPECT_EQ(cb_ffz32(2), 0);
  124. EXPECT_EQ(cb_ffz32(0xFF), 8);
  125. EXPECT_EQ(cb_ffz32(~zero), 0);
  126. for (unsigned int i = 0, v = 0; i < 31U; i++)
  127. {
  128. EXPECT_EQ(cb_ffz32(v), i);
  129. v = v | (one << i);
  130. }
  131. for (unsigned int i = 0; i < 32U; i++)
  132. {
  133. v = (~zero) & (~(one << i));
  134. EXPECT_EQ(cb_ffz32(v), i);
  135. }
  136. }
  137. TEST(testCase, cb_bitopt_ffz64_test01)
  138. {
  139. uint64_t v = 0ULL;
  140. unsigned long i;
  141. EXPECT_EQ(cb_ffz64(0x0ULL), 0);
  142. EXPECT_EQ(cb_ffz64(0x1ULL), 1);
  143. EXPECT_EQ(cb_ffz64(0x2ULL), 0);
  144. EXPECT_EQ(cb_ffz64(0x00000000FFFFFFFFULL), 32);
  145. EXPECT_EQ(cb_ffz64(0xFFFFFFFFFFFFFFFFULL), 0);
  146. for (i = 0, v = 0; i < 63UL; i++)
  147. {
  148. EXPECT_EQ(cb_ffz64(v), i);
  149. v = v | (0x1ULL << i);
  150. }
  151. for (i = 0; i < 64UL; i++)
  152. {
  153. v = 0xFFFFFFFFFFFFFFFFULL & (~(0x1ULL << i));
  154. EXPECT_EQ(cb_ffz64(v), i);
  155. }
  156. }
  157. TEST(testCase, cb_bitopt_ffz_test01)
  158. {
  159. unsigned long v;
  160. unsigned long one = 1UL;
  161. unsigned long zero = 0UL;
  162. unsigned long i;
  163. EXPECT_EQ(cb_ffz(~zero), 0);
  164. for (i = 0, v = 0; i < sizeof(unsigned long) * 8UL; i++)
  165. {
  166. EXPECT_EQ(cb_ffz(v), i);
  167. v = v | (0x1UL << i);
  168. }
  169. for (i = 0; i < sizeof(unsigned long) * 8UL; i++)
  170. {
  171. v = (~zero) & (~(one << i));
  172. EXPECT_EQ(cb_ffz(v), i);
  173. }
  174. }
  175. TEST(testCase, cb_bitopt_clz32_test01)
  176. {
  177. uint32_t v;
  178. uint32_t zero = 0x0U, one = 0x1U;
  179. unsigned long i;
  180. EXPECT_EQ(cb_clz32(0), 32);
  181. EXPECT_EQ(cb_clz32(1), 31);
  182. EXPECT_EQ(cb_clz32(2), 30);
  183. EXPECT_EQ(cb_clz32(0xF0), 24);
  184. EXPECT_EQ(cb_clz32(~zero), 0);
  185. for (i = 0, v = ~zero; i <= 32UL; i++)
  186. {
  187. EXPECT_EQ(cb_clz32(v), i);
  188. v = v >> 1U;
  189. }
  190. for (i = 0, v = one << 31U; i <= 32UL; i++)
  191. {
  192. EXPECT_EQ(cb_clz32(v), i);
  193. v = v >> 1U;
  194. }
  195. }
  196. TEST(testCase, cb_bitopt_clz64_test01)
  197. {
  198. uint64_t v;
  199. unsigned long i;
  200. EXPECT_EQ(cb_clz64(0), 64);
  201. EXPECT_EQ(cb_clz64(1), 63);
  202. EXPECT_EQ(cb_clz64(2), 62);
  203. EXPECT_EQ(cb_clz64(0xF0), 56);
  204. EXPECT_EQ(cb_clz64(0x00000000FFFFFFFFULL), 32);
  205. EXPECT_EQ(cb_clz64(0xFFFFFFFFFFFFFFFFULL), 0);
  206. for (i = 0, v = 0xFFFFFFFFFFFFFFFFULL; i <= 64UL; i++)
  207. {
  208. EXPECT_EQ(cb_clz64(v), i);
  209. v = v >> 1U;
  210. }
  211. for (i = 0, v = 0x8000000000000000ULL; i <= 64UL; i++)
  212. {
  213. EXPECT_EQ(cb_clz64(v), i);
  214. v = v >> 1U;
  215. }
  216. }
  217. TEST(testCase, cb_bitopt_clz_test01)
  218. {
  219. unsigned long v;
  220. unsigned long one = 1UL;
  221. unsigned long zero = 0UL;
  222. unsigned long i;
  223. for (i = 0, v = ~zero; i <= sizeof(unsigned long) * 8UL; i++)
  224. {
  225. EXPECT_EQ(cb_clz(v), i);
  226. v = v >> 1UL;
  227. }
  228. for (i = 0, v = one << (sizeof(unsigned long) * 8UL - 1UL); i <= sizeof(unsigned long) * 8UL; i++)
  229. {
  230. EXPECT_EQ(cb_clz(v), i);
  231. v = v >> 1UL;
  232. }
  233. }
  234. TEST(testCase, cb_bitopt_fls32_test01)
  235. {
  236. uint32_t v;
  237. uint32_t one = 0x1U;
  238. uint32_t i;
  239. EXPECT_EQ(cb_fls32(0), 0);
  240. EXPECT_EQ(cb_fls32(1), 1);
  241. EXPECT_EQ(cb_fls32(0xF0), 8);
  242. EXPECT_EQ(cb_fls32(0x80000000), 32);
  243. EXPECT_EQ(cb_fls32(0x80000001), 32);
  244. EXPECT_EQ(cb_fls32(0xFFFFFFFF), 32);
  245. for (i = 0, v = 0U; i < 32UL; i++)
  246. {
  247. EXPECT_EQ(cb_fls32(v), i);
  248. v = one << i;
  249. }
  250. for (i = 0, v = 0; i < 32UL; i++)
  251. {
  252. EXPECT_EQ(cb_fls32(v), i);
  253. v |= one << i;
  254. }
  255. }
  256. TEST(testCase, cb_bitopt_fls64_test01)
  257. {
  258. uint64_t v;
  259. unsigned long i;
  260. EXPECT_EQ(cb_fls64(0), 0);
  261. EXPECT_EQ(cb_fls64(1), 1);
  262. EXPECT_EQ(cb_fls64(0xF0), 8);
  263. EXPECT_EQ(cb_fls64(0x80000000ULL), 32);
  264. EXPECT_EQ(cb_fls64(0x8000000000000000ULL), 64);
  265. EXPECT_EQ(cb_fls64(0x8000000000000001ULL), 64);
  266. EXPECT_EQ(cb_fls64(0xFFFFFFFFFFFFFFFFULL), 64);
  267. for (i = 0, v = 0; i < 64UL; i++)
  268. {
  269. EXPECT_EQ(cb_fls64(v), i);
  270. v = 0x1ULL << i;
  271. }
  272. for (i = 0, v = 0; i < 64UL; i++)
  273. {
  274. EXPECT_EQ(cb_fls64(v), i);
  275. v |= 0x1ULL << i;
  276. }
  277. }
  278. TEST(testCase, cb_bitopt_fls_test01)
  279. {
  280. unsigned long v;
  281. unsigned long i;
  282. for (i = 0, v = 0; i < sizeof(unsigned long) * 8UL; i++)
  283. {
  284. EXPECT_EQ(cb_fls(v), i);
  285. v = 0x1UL << i;
  286. }
  287. for (i = 0, v = 0; i < sizeof(unsigned long) * 8UL; i++)
  288. {
  289. EXPECT_EQ(cb_fls(v), i);
  290. v |= 0x1UL << i;
  291. }
  292. }
  293. TEST(testCase, cb_bitopt_ctz32_test01)
  294. {
  295. uint32_t v;
  296. unsigned long i;
  297. EXPECT_EQ(cb_ctz32(0), 32);
  298. EXPECT_EQ(cb_ctz32(2), 1);
  299. EXPECT_EQ(cb_ctz32(0x80000000), 31);
  300. EXPECT_EQ(cb_ctz32(0xFFFFFFFF), 0);
  301. v = 0U;
  302. v = ~v;
  303. for (i = 0; i <= 32UL; i++)
  304. {
  305. EXPECT_EQ(cb_ctz32(v), i);
  306. v = v << 0x1U;
  307. }
  308. for (i = 0, v = 1U; i <= 32UL; i++)
  309. {
  310. EXPECT_EQ(cb_ctz32(v), i);
  311. v = v << 0x1U;
  312. }
  313. }
  314. TEST(testCase, cb_bitopt_ctz64_test01)
  315. {
  316. uint64_t v;
  317. unsigned long i;
  318. EXPECT_EQ(cb_ctz64(0), 64);
  319. EXPECT_EQ(cb_ctz64(2), 1);
  320. EXPECT_EQ(cb_ctz64(3), 0);
  321. EXPECT_EQ(cb_ctz64(0x80000000ULL), 31);
  322. EXPECT_EQ(cb_ctz64(0xFFFFFFFFFFFFFFFFULL), 0);
  323. v = 0ULL;
  324. v = ~v;
  325. for (i = 0; i <= 64UL; i++)
  326. {
  327. EXPECT_EQ(cb_ctz64(v), i);
  328. v = v << 0x1ULL;
  329. }
  330. for (i = 0, v = 1ULL; i <= 64UL; i++)
  331. {
  332. EXPECT_EQ(cb_ctz64(v), i);
  333. v = v << 0x1ULL;
  334. }
  335. }
  336. TEST(testCase, cb_bitopt_ctz_test01)
  337. {
  338. unsigned long v;
  339. unsigned long i;
  340. v = 0UL;
  341. v = ~v;
  342. for (i = 0; i <= sizeof(unsigned long) * 8UL; i++)
  343. {
  344. EXPECT_EQ(cb_ctz(v), i);
  345. v = v << 0x1UL;
  346. }
  347. for (i = 0, v = 1UL; i <= sizeof(unsigned long) * 8UL; i++)
  348. {
  349. EXPECT_EQ(cb_ctz(v), i);
  350. v = v << 0x1UL;
  351. }
  352. }
  353. TEST(testCase, cb_bitopt_find_next_bit_test01)
  354. {
  355. unsigned long bits[4];
  356. unsigned long i, len;
  357. for (len = 0; len <= sizeof(bits) * 8; len++)
  358. {
  359. memset(bits, 0x00, sizeof(bits));
  360. for (i = 0; i < len * 2; i++)
  361. {
  362. EXPECT_EQ(cb_find_next_bit(bits, len, i), len);
  363. }
  364. memset(bits, 0xFF, sizeof(bits));
  365. for (i = 0; i <= len; i++)
  366. {
  367. EXPECT_EQ(cb_find_next_bit(bits, len, i), i);
  368. }
  369. for (i = 0; i < len; i++)
  370. {
  371. memset(bits, 0x00, sizeof(bits));
  372. cb_setbit(bits, i);
  373. EXPECT_EQ(cb_find_next_bit(bits, len, 0), i);
  374. }
  375. }
  376. }
  377. TEST(testCase, cb_for_each_set_bit_test01)
  378. {
  379. unsigned long bits[4];
  380. unsigned long i, len;
  381. unsigned long cnt, bit;
  382. for (len = 0; len <= sizeof(bits) * 8; len++)
  383. {
  384. memset(bits, 0x00, sizeof(bits));
  385. bit = ~0x0UL;
  386. for (i = 0; i < len * 2; i++)
  387. {
  388. cnt = 0;
  389. cb_for_each_set_bit(bit, bits, len)
  390. {
  391. cnt += 1;
  392. }
  393. EXPECT_EQ(cnt, 0);
  394. }
  395. memset(bits, 0xFF, sizeof(bits));
  396. for (i = 0; i < len; i++)
  397. {
  398. cnt = 0UL;
  399. cb_for_each_set_bit(bit, bits, len)
  400. {
  401. EXPECT_EQ(bit, cnt);
  402. cnt += 1UL;
  403. }
  404. EXPECT_EQ(cnt, len);
  405. }
  406. for (i = 0; i < len; i++)
  407. {
  408. cnt = 0;
  409. memset(bits, 0x00, sizeof(bits));
  410. cb_setbit(bits, i);
  411. cb_for_each_set_bit(bit, bits, len)
  412. {
  413. EXPECT_EQ(bit, i);
  414. EXPECT_EQ(cnt, 0);
  415. cnt += 1;
  416. }
  417. EXPECT_EQ(cnt, 1);
  418. }
  419. }
  420. }