tz_ndbg.c 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. #include "tz_ndbg.h"
  2. #ifdef CC_ENABLE_NDBG
  3. #include <linux/module.h>
  4. #include <linux/types.h>
  5. #include <linux/slab.h>
  6. #include <linux/delay.h>
  7. #include <linux/kthread.h>
  8. #include <linux/fs.h>
  9. #include <linux/uaccess.h>
  10. #include <linux/init.h>
  11. #include <linux/random.h>
  12. #if 0
  13. #include <mach/battery_meter.h>
  14. #endif
  15. #include "tz_cross/trustzone.h"
  16. #include "tz_cross/ta_test.h"
  17. #include "tz_cross/ta_mem.h"
  18. #include "tz_cross/ta_ndbg.h"
  19. #include "trustzone/kree/system.h"
  20. #include "trustzone/kree/mem.h"
  21. #include "kree_int.h"
  22. int entropy_thread(void *arg)
  23. {
  24. TZ_RESULT ret;
  25. KREE_SESSION_HANDLE ndbg_session;
  26. KREE_SESSION_HANDLE mem_session;
  27. KREE_SHAREDMEM_HANDLE shm_handle;
  28. KREE_SHAREDMEM_PARAM shm_param;
  29. MTEEC_PARAM param[4];
  30. uint8_t *ptr;
  31. ptr = kmalloc(NDBG_REE_ENTROPY_SZ, GFP_KERNEL);
  32. memset(ptr, 0, NDBG_REE_ENTROPY_SZ);
  33. while (!kthread_should_stop()) {
  34. ret = KREE_CreateSession(TZ_TA_NDBG_UUID, &ndbg_session);
  35. if (ret != TZ_RESULT_SUCCESS) {
  36. pr_warn("CreateSession error %d\n", ret);
  37. return 1;
  38. }
  39. ret = KREE_CreateSession(TZ_TA_MEM_UUID, &mem_session);
  40. if (ret != TZ_RESULT_SUCCESS) {
  41. pr_warn("Create memory session error %d\n", ret);
  42. return 1;
  43. }
  44. shm_param.buffer = ptr;
  45. shm_param.size = NDBG_REE_ENTROPY_SZ;
  46. ret = KREE_RegisterSharedmem(mem_session, &shm_handle,
  47. &shm_param);
  48. if (ret != TZ_RESULT_SUCCESS) {
  49. pr_warn("KREE_RegisterSharedmem Error: %s\n",
  50. TZ_GetErrorString(ret));
  51. return 1;
  52. }
  53. #if 0
  54. *((uint32_t *)(ptr + 0)) = battery_meter_get_battery_voltage();
  55. *((uint32_t *)(ptr + 4)) = battery_meter_get_VSense();
  56. *((uint32_t *)(ptr + 8)) = battery_meter_get_charger_voltage();
  57. *((uint32_t *)(ptr + 12)) = battery_meter_get_charger_voltage();
  58. get_random_bytes(ptr + NDBG_BAT_ST_SIZE, URAN_SIZE);
  59. #else
  60. get_random_bytes(ptr, NDBG_REE_ENTROPY_SZ);
  61. #endif
  62. param[0].memref.handle = (uint32_t) shm_handle;
  63. param[0].memref.offset = 0;
  64. param[0].memref.size = NDBG_REE_ENTROPY_SZ;
  65. param[1].value.a = NDBG_REE_ENTROPY_SZ;
  66. ret = KREE_TeeServiceCall((KREE_SESSION_HANDLE) ndbg_session,
  67. TZCMD_NDBG_INIT,
  68. TZ_ParamTypes3(TZPT_MEMREF_INPUT,
  69. TZPT_VALUE_INPUT,
  70. TZPT_VALUE_OUTPUT),
  71. param);
  72. if (ret != TZ_RESULT_SUCCESS)
  73. pr_warn("TZCMD_NDBG_INIT fail, reason:%s\n",
  74. TZ_GetErrorString(ret));
  75. pr_debug("Start to wait reseed.\n");
  76. ret = KREE_TeeServiceCall((KREE_SESSION_HANDLE) ndbg_session,
  77. TZCMD_NDBG_WAIT_RESEED,
  78. TZ_ParamTypes3(TZPT_MEMREF_INPUT,
  79. TZPT_VALUE_INPUT,
  80. TZPT_VALUE_OUTPUT),
  81. param);
  82. if (ret != TZ_RESULT_SUCCESS)
  83. pr_warn("TZCMD_NDBG_WAIT_RESEED fail, reason:%s\n",
  84. TZ_GetErrorString(ret));
  85. pr_debug("OK to send reseed.\n");
  86. ret = KREE_UnregisterSharedmem(mem_session, shm_handle);
  87. if (ret != TZ_RESULT_SUCCESS) {
  88. pr_warn("KREE_UnregisterSharedmem Error: %s\n",
  89. TZ_GetErrorString(ret));
  90. return 1;
  91. }
  92. ret = KREE_CloseSession(ndbg_session);
  93. if (ret != TZ_RESULT_SUCCESS)
  94. pr_warn("CloseSession error %d\n", ret);
  95. ret = KREE_CloseSession(mem_session);
  96. if (ret != TZ_RESULT_SUCCESS)
  97. pr_warn("Close memory session error %d\n", ret);
  98. }
  99. kfree(ptr);
  100. return 0;
  101. }
  102. #ifdef CC_NDBG_TEST_PROGRAM
  103. int test_random_thread(void *arg)
  104. {
  105. TZ_RESULT ret;
  106. KREE_SESSION_HANDLE ndbg_session;
  107. KREE_SESSION_HANDLE mem_session;
  108. KREE_SHAREDMEM_HANDLE shm_handle;
  109. KREE_SHAREDMEM_PARAM shm_param;
  110. MTEEC_PARAM param[4];
  111. uint32_t *ptr;
  112. int size = 32;
  113. ptr = kmalloc(size, GFP_KERNEL);
  114. memset(ptr, 0, size);
  115. while (!kthread_should_stop()) {
  116. ret = KREE_CreateSession(TZ_TA_NDBG_UUID, &ndbg_session);
  117. if (ret != TZ_RESULT_SUCCESS) {
  118. pr_warn("CreateSession error %d\n", ret);
  119. return 1;
  120. }
  121. ret = KREE_CreateSession(TZ_TA_MEM_UUID, &mem_session);
  122. if (ret != TZ_RESULT_SUCCESS) {
  123. pr_warn("Create memory session error %d\n", ret);
  124. return 1;
  125. }
  126. shm_param.buffer = ptr;
  127. shm_param.size = size;
  128. ret = KREE_RegisterSharedmem(mem_session, &shm_handle,
  129. &shm_param);
  130. if (ret != TZ_RESULT_SUCCESS) {
  131. pr_warn("KREE_RegisterSharedmem Error: %s\n",
  132. TZ_GetErrorString(ret));
  133. return 1;
  134. }
  135. param[0].memref.handle = (uint32_t) shm_handle;
  136. param[0].memref.offset = 0;
  137. param[0].memref.size = size / 4;
  138. param[1].value.a = size / 4;
  139. ret = KREE_TeeServiceCall((KREE_SESSION_HANDLE) ndbg_session,
  140. TZCMD_NDBG_RANDOM,
  141. TZ_ParamTypes3(TZPT_MEMREF_INPUT,
  142. TZPT_VALUE_INPUT,
  143. TZPT_VALUE_OUTPUT),
  144. param);
  145. ret = KREE_UnregisterSharedmem(mem_session, shm_handle);
  146. if (ret != TZ_RESULT_SUCCESS) {
  147. pr_warn("KREE_UnregisterSharedmem Error: %s\n",
  148. TZ_GetErrorString(ret));
  149. return 1;
  150. }
  151. ret = KREE_CloseSession(ndbg_session);
  152. if (ret != TZ_RESULT_SUCCESS)
  153. pr_warn("CloseSession error %d\n", ret);
  154. ret = KREE_CloseSession(mem_session);
  155. if (ret != TZ_RESULT_SUCCESS)
  156. pr_warn("Close memory session error %d\n", ret);
  157. ssleep(5);
  158. }
  159. kfree(ptr);
  160. return 0;
  161. }
  162. #endif
  163. int __init tz_ndbg_init(void)
  164. {
  165. kthread_run(entropy_thread, NULL, "entropy_thread");
  166. #ifdef CC_NDBG_TEST_PROGRAM
  167. kthread_run(test_random_thread, NULL, "test_random_thread");
  168. #endif
  169. return 0;
  170. }
  171. late_initcall(tz_ndbg_init);
  172. #endif