test.h 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. /*
  2. * Copyright (c) 2013 Google, Inc.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #ifndef __DM_TEST_H
  7. #define __DM_TEST_H
  8. #include <dm.h>
  9. #include <test/test.h>
  10. /**
  11. * struct dm_test_cdata - configuration data for test instance
  12. *
  13. * @ping_add: Amonut to add each time we get a ping
  14. * @base: Base address of this device
  15. */
  16. struct dm_test_pdata {
  17. int ping_add;
  18. uint32_t base;
  19. };
  20. /**
  21. * struct test_ops - Operations supported by the test device
  22. *
  23. * @ping: Ping operation
  24. * @dev: Device to operate on
  25. * @pingval: Value to ping the device with
  26. * @pingret: Returns resulting value from driver
  27. * @return 0 if OK, -ve on error
  28. */
  29. struct test_ops {
  30. int (*ping)(struct udevice *dev, int pingval, int *pingret);
  31. };
  32. /* Operations that our test driver supports */
  33. enum {
  34. DM_TEST_OP_BIND = 0,
  35. DM_TEST_OP_UNBIND,
  36. DM_TEST_OP_PROBE,
  37. DM_TEST_OP_REMOVE,
  38. /* For uclass */
  39. DM_TEST_OP_POST_BIND,
  40. DM_TEST_OP_PRE_UNBIND,
  41. DM_TEST_OP_PRE_PROBE,
  42. DM_TEST_OP_POST_PROBE,
  43. DM_TEST_OP_PRE_REMOVE,
  44. DM_TEST_OP_INIT,
  45. DM_TEST_OP_DESTROY,
  46. DM_TEST_OP_COUNT,
  47. };
  48. /* Test driver types */
  49. enum {
  50. DM_TEST_TYPE_FIRST = 0,
  51. DM_TEST_TYPE_SECOND,
  52. };
  53. /* The number added to the ping total on each probe */
  54. #define DM_TEST_START_TOTAL 5
  55. /**
  56. * struct dm_test_priv - private data for the test devices
  57. */
  58. struct dm_test_priv {
  59. int ping_total;
  60. int op_count[DM_TEST_OP_COUNT];
  61. int uclass_flag;
  62. int uclass_total;
  63. };
  64. /**
  65. * struct dm_test_perdev_class_priv - private per-device data for test uclass
  66. */
  67. struct dm_test_uclass_perdev_priv {
  68. int base_add;
  69. };
  70. /**
  71. * struct dm_test_uclass_priv - private data for test uclass
  72. */
  73. struct dm_test_uclass_priv {
  74. int total_add;
  75. };
  76. /**
  77. * struct dm_test_parent_data - parent's information on each child
  78. *
  79. * @sum: Test value used to check parent data works correctly
  80. * @flag: Used to track calling of parent operations
  81. * @uclass_flag: Used to track calling of parent operations by uclass
  82. */
  83. struct dm_test_parent_data {
  84. int sum;
  85. int flag;
  86. };
  87. /* Test values for test device's uclass platform data */
  88. enum {
  89. TEST_UC_PDATA_INTVAL1 = 2,
  90. TEST_UC_PDATA_INTVAL2 = 334,
  91. TEST_UC_PDATA_INTVAL3 = 789452,
  92. };
  93. /**
  94. * struct dm_test_uclass_platda - uclass's information on each device
  95. *
  96. * @intval1: set to TEST_UC_PDATA_INTVAL1 in .post_bind method of test uclass
  97. * @intval2: set to TEST_UC_PDATA_INTVAL2 in .post_bind method of test uclass
  98. * @intval3: set to TEST_UC_PDATA_INTVAL3 in .post_bind method of test uclass
  99. */
  100. struct dm_test_perdev_uc_pdata {
  101. int intval1;
  102. int intval2;
  103. int intval3;
  104. };
  105. /*
  106. * Operation counts for the test driver, used to check that each method is
  107. * called correctly
  108. */
  109. extern int dm_testdrv_op_count[DM_TEST_OP_COUNT];
  110. extern struct unit_test_state global_dm_test_state;
  111. /*
  112. * struct dm_test_state - Entire state of dm test system
  113. *
  114. * This is often abreviated to dms.
  115. *
  116. * @root: Root device
  117. * @testdev: Test device
  118. * @force_fail_alloc: Force all memory allocs to fail
  119. * @skip_post_probe: Skip uclass post-probe processing
  120. * @removed: Used to keep track of a device that was removed
  121. */
  122. struct dm_test_state {
  123. struct udevice *root;
  124. struct udevice *testdev;
  125. int force_fail_alloc;
  126. int skip_post_probe;
  127. struct udevice *removed;
  128. };
  129. /* Test flags for each test */
  130. enum {
  131. DM_TESTF_SCAN_PDATA = 1 << 0, /* test needs platform data */
  132. DM_TESTF_PROBE_TEST = 1 << 1, /* probe test uclass */
  133. DM_TESTF_SCAN_FDT = 1 << 2, /* scan device tree */
  134. };
  135. /* Declare a new driver model test */
  136. #define DM_TEST(_name, _flags) UNIT_TEST(_name, _flags, dm_test)
  137. /* This platform data is needed in tests, so declare it here */
  138. struct sandbox_sdl_plat {
  139. int xres;
  140. int yres;
  141. int bpix;
  142. int rot;
  143. const char *vidconsole_drv_name;
  144. int font_size;
  145. };
  146. /* Declare ping methods for the drivers */
  147. int test_ping(struct udevice *dev, int pingval, int *pingret);
  148. int testfdt_ping(struct udevice *dev, int pingval, int *pingret);
  149. /**
  150. * dm_check_operations() - Check that we can perform ping operations
  151. *
  152. * This checks that the ping operations work as expected for a device
  153. *
  154. * @dms: Overall test state
  155. * @dev: Device to test
  156. * @base: Base address, used to check ping return value
  157. * @priv: Pointer to private test information
  158. * @return 0 if OK, -ve on error
  159. */
  160. int dm_check_operations(struct unit_test_state *uts, struct udevice *dev,
  161. uint32_t base, struct dm_test_priv *priv);
  162. /**
  163. * dm_check_devices() - check the devices respond to operations correctly
  164. *
  165. * @dms: Overall test state
  166. * @num_devices: Number of test devices to check
  167. * @return 0 if OK, -ve on error
  168. */
  169. int dm_check_devices(struct unit_test_state *uts, int num_devices);
  170. /**
  171. * dm_leak_check_start() - Prepare to check for a memory leak
  172. *
  173. * Call this before allocating memory to record the amount of memory being
  174. * used.
  175. *
  176. * @dms: Overall test state
  177. */
  178. void dm_leak_check_start(struct unit_test_state *uts);
  179. /**
  180. * dm_leak_check_end() - Check that no memory has leaked
  181. *
  182. * Call this after dm_leak_check_start() and after you have hopefuilly freed
  183. * all the memory that was allocated. This function will print an error if
  184. * it sees a different amount of total memory allocated than before.
  185. *
  186. * @dms: Overall test state
  187. */int dm_leak_check_end(struct unit_test_state *uts);
  188. #endif