sd8563_timer_acts.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634
  1. /*
  2. * Copyright (c) 2024 Wingcool Technology Co., Ltd
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. /**
  7. * @file
  8. * @brief SD8563 Timer driver for Actions SoC
  9. */
  10. #include <errno.h>
  11. #include <kernel.h>
  12. #include <string.h>
  13. //#include <stdbool.h>
  14. #include <init.h>
  15. #include <irq.h>
  16. #include <drivers/adc.h>
  17. #include <drivers/input/input_dev.h>
  18. #include <sys/util.h>
  19. #include <sys/byteorder.h>
  20. #include <board.h>
  21. #include <soc_pmu.h>
  22. #include <logging/log.h>
  23. #include <device.h>
  24. #include <drivers/gpio.h>
  25. #include <soc.h>
  26. #include <string.h>
  27. #include <drivers/i2c.h>
  28. //#include <board_cfg.h>
  29. #include <drivers/uart.h>
  30. LOG_MODULE_REGISTER(sd8563, CONFIG_SYS_LOG_INPUT_DEV_LEVEL);
  31. #define rtc_slaver_addr (0xA2 >> 1)// 0x51
  32. //#ifndef CONFIG_MERGE_WORK_Q
  33. //#define CONFIG_USED_TP_WORK_QUEUE 0
  34. //#endif
  35. #ifdef CONFIG_USED_TP_WORK_QUEUE
  36. #define CONFIG_TIMER_WORK_Q_STACK_SIZE 1280
  37. struct k_work_q timer_drv_q;
  38. K_THREAD_STACK_DEFINE(timer_work_q_stack, CONFIG_TIMER_WORK_Q_STACK_SIZE);
  39. #endif
  40. struct acts_timer_data {
  41. input_notify_t notify;
  42. const struct device *i2c_dev;
  43. const struct device *gpio_dev;
  44. const struct device *this_dev;
  45. struct gpio_callback key_gpio_cb;
  46. struct k_work init_timer;
  47. bool inited;
  48. #ifdef CONFIG_PM_DEVICE
  49. uint32_t pm_state;
  50. #endif
  51. };
  52. uint16_t timer_crc[2] __attribute((used)) = {0};
  53. uint8_t read_time_data[7] = {0};
  54. bool bInitTimeData; // 0: no need to init; 1: need to init
  55. static struct acts_timer_data timer_acts_ddata;
  56. static int _sd8563_close_write_protection(const struct device *i2c_dev);
  57. static void _sd8563_open_write_protection(const struct device *i2c_dev);
  58. static void _sd8563_read_time(const struct device *i2c_dev, bool is_uart_send);
  59. static void _sd8563_set_time(const struct device *i2c_dev,
  60. uint8_t set_hour,
  61. uint8_t set_minute,
  62. uint8_t set_week,
  63. uint16_t set_year,
  64. uint8_t set_month,
  65. uint8_t set_day);
  66. extern void uart2_poll_out_ch(int c);
  67. extern uint8_t bySetHour;
  68. extern uint8_t bySetMinute;
  69. extern uint8_t bySetWeekday;
  70. extern uint16_t wSetYear;
  71. extern uint8_t bySetMonth;
  72. extern uint8_t bySetDay;
  73. extern uint8_t bySetTimeStep;
  74. #include <drivers/hrtimer.h>
  75. #if 1
  76. static struct hrtimer g_rtc_ht_read;
  77. static void timer_acts_handler(struct k_work *work)
  78. {
  79. static struct acts_timer_data *external_rtc = &timer_acts_ddata;
  80. if (((bySetHour != 0xff) || (wSetYear != 0xff))
  81. && ((bySetTimeStep == 0) || (bySetTimeStep == 2))
  82. )
  83. {
  84. hrtimer_stop(&g_rtc_ht_read);
  85. if (_sd8563_close_write_protection(external_rtc->i2c_dev) == 1)
  86. {
  87. _sd8563_set_time(external_rtc->i2c_dev, bySetHour, bySetMinute, bySetWeekday, wSetYear, bySetMonth, bySetDay);
  88. _sd8563_open_write_protection(external_rtc->i2c_dev);
  89. }
  90. k_msleep(100);
  91. _sd8563_read_time(external_rtc->i2c_dev, false); //读一次,避免用户在设置后再次快速进入设置界面时数据不正确
  92. hrtimer_restart(&g_rtc_ht_read);
  93. bySetHour = 0xff;
  94. bySetMinute = 0xff;
  95. bySetWeekday = 0xff;
  96. wSetYear = 0xff;
  97. bySetMonth = 0xff;
  98. bySetDay = 0xff;
  99. if (bySetTimeStep)
  100. {
  101. bySetTimeStep = 3; //设置完成
  102. }
  103. return;
  104. }
  105. _sd8563_read_time(external_rtc->i2c_dev, true); //不在ISR中完成,防止中断嵌套
  106. }
  107. K_WORK_DEFINE(timer_acts, timer_acts_handler);
  108. static void htimer_fun(struct hrtimer *ttimer, void *expiry_fn_arg)
  109. {
  110. //static int t;
  111. //static struct acts_timer_data *external_rtc = &timer_acts_ddata;
  112. //printk("%d ---htimer--\n", t++);
  113. //_sd8563_read_time(external_rtc->i2c_dev, true); //不在ISR中完成,防止中断嵌套
  114. k_work_submit(&timer_acts); //向系统工作队列提交一个工作项,让工作队列的线程将执行该工作
  115. }
  116. static void htimer_read(unsigned int ms)
  117. {
  118. hrtimer_init(&g_rtc_ht_read, htimer_fun, NULL);
  119. hrtimer_start(&g_rtc_ht_read, 1000*ms, 1000*ms);
  120. }
  121. #endif
  122. static void _sd8563_open_write_protection(const struct device *i2c_dev)
  123. {
  124. #if 1
  125. uint8_t write_cmd[2] = {0};
  126. uint8_t read_cmd[7] = {0};
  127. int ret = 0;
  128. printk("_sd8563_read_write_protection\n");
  129. ret = i2c_write_read(i2c_dev, rtc_slaver_addr, write_cmd, 1, read_cmd, 1);
  130. if (ret != 0)
  131. {
  132. printk("i2c_write_read ERR\n");
  133. }
  134. printk("CTR1 = %d\n", read_cmd[0]);
  135. if (read_cmd[0] & 0x40) //bit6:WRTC=1,write_protection has been opened
  136. {
  137. printk("write_protection has been opened\n");
  138. return;
  139. }
  140. //open_write_protection: 0E寄存器的bit6~bit2依次写入b0000、b10101、b01010、b10111
  141. write_cmd[0] = 0x0E;
  142. ret = i2c_write_read(i2c_dev, rtc_slaver_addr, write_cmd, 1, read_cmd, 1);
  143. if (ret != 0)
  144. {
  145. printk("i2c_write_read ERR\n");
  146. }
  147. read_cmd[0] = (read_cmd[0] & 0x83);
  148. //bit6~bit2 write b0000
  149. write_cmd[1] = read_cmd[0];
  150. ret = i2c_write(i2c_dev, write_cmd, 2, rtc_slaver_addr);
  151. if (ret != 0)
  152. {
  153. printk("step1 i2c write ERR\n");
  154. return;
  155. }
  156. //bit6~bit2 write b10101
  157. write_cmd[1] = read_cmd[0] | 0x54;
  158. ret = i2c_write(i2c_dev, write_cmd, 2, rtc_slaver_addr);
  159. if (ret != 0)
  160. {
  161. printk("step2 i2c write ERR\n");
  162. return;
  163. }
  164. //bit6~bit2 write b01010
  165. write_cmd[1] = read_cmd[0] | 0x28;
  166. ret = i2c_write(i2c_dev, write_cmd, 2, rtc_slaver_addr);
  167. if (ret != 0)
  168. {
  169. printk("step3 i2c write ERR\n");
  170. return;
  171. }
  172. //bit6~bit2 write b10111
  173. write_cmd[1] = read_cmd[0] | 0x5C;
  174. ret = i2c_write(i2c_dev, write_cmd, 2, rtc_slaver_addr);
  175. if (ret != 0)
  176. {
  177. printk("step4 i2c write ERR\n");
  178. return;
  179. }
  180. k_msleep(1);
  181. write_cmd[0] = 0; //CTR1
  182. ret = i2c_write_read(i2c_dev, rtc_slaver_addr, write_cmd, 1, read_cmd, 1);
  183. if (ret != 0)
  184. {
  185. printk("i2c_write_read ERR\n");
  186. }
  187. printk("CTR1 = %d\n", read_cmd[0]);
  188. if (read_cmd[0] & 0x40) //bit6:WRTC=1,write_protection has been opened
  189. {
  190. printk("write_protection has been opened\n");
  191. }
  192. printk("_sd8563_open_write_protection exit\n");
  193. #endif
  194. }
  195. static int _sd8563_close_write_protection(const struct device *i2c_dev)
  196. {
  197. #if 1
  198. uint8_t write_cmd[2] = {0};
  199. uint8_t read_cmd[7] = {0};
  200. int ret = 0;
  201. printk("_sd8563_read_write_protection\n");
  202. ret = i2c_write_read(i2c_dev, rtc_slaver_addr, write_cmd, 1, read_cmd, 1);
  203. if (ret != 0)
  204. {
  205. printk("i2c_write_read ERR\n");
  206. return 0;
  207. }
  208. printk("CTR1 = %d\n", read_cmd[0]);
  209. if ((read_cmd[0] & 0x40) == 0) //bit6:WRTC = 0,write_protection has been closed
  210. {
  211. printk("write_protection has been closed\n");
  212. return 1;
  213. }
  214. //close_write_protection: 0E寄存器的bit6~bit2依次写入b0000、b11100、b00011、b01110
  215. write_cmd[0] = 0x0E;
  216. ret = i2c_write_read(i2c_dev, rtc_slaver_addr, write_cmd, 1, read_cmd, 1);
  217. if (ret != 0)
  218. {
  219. printk("i2c_write_read ERR\n");
  220. return 0;
  221. }
  222. read_cmd[0] = (read_cmd[0] & 0x83);
  223. //bit6~bit2 write b0000
  224. write_cmd[1] = read_cmd[0];
  225. ret = i2c_write(i2c_dev, write_cmd, 2, rtc_slaver_addr);
  226. if (ret != 0)
  227. {
  228. printk("step1 i2c write ERR\n");
  229. return 0;
  230. }
  231. //bit6~bit2 write b11100
  232. write_cmd[1] = read_cmd[0] | 0x70;
  233. ret = i2c_write(i2c_dev, write_cmd, 2, rtc_slaver_addr);
  234. if (ret != 0)
  235. {
  236. printk("step2 i2c write ERR\n");
  237. return 0;
  238. }
  239. //bit6~bit2 write b00011
  240. write_cmd[1] = read_cmd[0] | 0x0C;
  241. ret = i2c_write(i2c_dev, write_cmd, 2, rtc_slaver_addr);
  242. if (ret != 0)
  243. {
  244. printk("step3 i2c write ERR\n");
  245. return 0;
  246. }
  247. //bit6~bit2 write b01110
  248. write_cmd[1] = read_cmd[0] | 0x38;
  249. ret = i2c_write(i2c_dev, write_cmd, 2, rtc_slaver_addr);
  250. if (ret != 0)
  251. {
  252. printk("step4 i2c write ERR\n");
  253. return 0;
  254. }
  255. k_msleep(1);
  256. write_cmd[0] = 0; //CTR1
  257. ret = i2c_write_read(i2c_dev, rtc_slaver_addr, write_cmd, 1, read_cmd, 1);
  258. if (ret != 0)
  259. {
  260. printk("i2c_write_read ERR\n");
  261. return 0;
  262. }
  263. printk("CTR1 = %d\n", read_cmd[0]);
  264. if ((read_cmd[0] & 0x40) == 0) //bit6:WRTC = 0,write_protection has been closed
  265. {
  266. printk("write_protection has been closed\n");
  267. return 1;
  268. }
  269. printk("_sd8563_close_write_protection exit\n");
  270. return 0;
  271. #else
  272. return 1;
  273. #endif
  274. }
  275. static void _sd8563_set_time(const struct device *i2c_dev,
  276. uint8_t set_hour,
  277. uint8_t set_minute,
  278. uint8_t set_week,
  279. uint16_t set_year,
  280. uint8_t set_month,
  281. uint8_t set_day)
  282. {
  283. #if 1
  284. uint8_t write_cmd[8] = {0};
  285. uint8_t read_cmd[7] = {0};
  286. int ret = 0;
  287. printk("_sd8563_set_time start\n");
  288. write_cmd[0] = 0x02; //sec
  289. ret = i2c_write_read(i2c_dev, rtc_slaver_addr, write_cmd, 1, read_cmd, 1);
  290. if (ret != 0)
  291. {
  292. printk("i2c_write_read ERR\n");
  293. return;
  294. }
  295. if ((set_hour == 0xFF) && (set_year == 0xFF)) //power on
  296. {
  297. printk("read_cmd[0] = %d\n", read_cmd[0]);
  298. if ((read_cmd[0] & 0x80) == 0) //bit7:0SF/
  299. {
  300. printk("bit7:0SF is 0,The time has been set\n");
  301. return;
  302. }
  303. bInitTimeData = true; //need to init time
  304. }
  305. _sd8563_read_time(i2c_dev, false); //read time
  306. //printk("y:%x, mon:%x, week:%x, d:%x, h:%x, min:%x, sec:%x\n",
  307. // read_time_data[6], read_time_data[5], read_time_data[4], read_time_data[3], read_time_data[2], read_time_data[1], read_time_data[0]);
  308. if(set_hour != 0xFF)
  309. {
  310. read_time_data[0] = 0;
  311. set_minute = (set_minute / 10) * 16 + set_minute % 10; //DEC TO BCD CODE
  312. set_hour = (set_hour / 10) * 16 + set_hour % 10; //DEC TO BCD CODE
  313. read_time_data[1] = set_minute;//(set_minute / 10) * 16 + set_minute % 10; //DEC TO BCD CODE
  314. read_time_data[2] = set_hour;//(set_hour / 10) * 16 + set_hour % 10; //DEC TO BCD CODE
  315. read_time_data[4] = set_week % 7;//0:Sun. 1:Mon. 2:Tue. 3:Wed. 4:Thu. 5:Fri. 6:Sat.
  316. }
  317. if (set_year != 0xFF)
  318. {
  319. if (set_year >= 2000)
  320. {
  321. set_year = set_year - 2000;
  322. }
  323. set_day = (set_day / 10) * 16 + set_day % 10; //DEC TO BCD CODE
  324. set_month = (set_month / 10) * 16 + set_month % 10; //DEC TO BCD CODE
  325. set_year = (set_year / 10) * 16 + set_year % 10; //DEC TO BCD CODE
  326. read_time_data[3] = set_day;//(set_day / 10) * 16 + set_day % 10; //DEC TO BCD CODE
  327. read_time_data[5] = set_month;//(set_month / 10) * 16 + set_month % 10; //DEC TO BCD CODE
  328. read_time_data[6] = set_year;//(set_year / 10) * 16 + set_year % 10; //DEC TO BCD CODE
  329. }
  330. if (bInitTimeData == true) //need to init time
  331. {
  332. //BCD code
  333. write_cmd[1] = 0; //sec
  334. write_cmd[2] = 0x00; //min
  335. write_cmd[3] = 0x00; //hour
  336. write_cmd[4] = 0x01; //day
  337. write_cmd[5] = 0x06; //week
  338. write_cmd[6] = 0x01; //mon
  339. write_cmd[7] = 0x00; //year
  340. printk("power on set time and date\n");
  341. }
  342. else
  343. {
  344. //BCD code
  345. for (uint8_t i = 0; i < 7; i++)
  346. {
  347. write_cmd[i + 1] = read_time_data[i];//(read_time_data[i] / 10) * 16 + read_time_data[i] % 10; //DEC TO BCD CODE
  348. }
  349. //write_cmd[1] = read_time_data[0]; //sec
  350. //write_cmd[2] = read_time_data[1]; //min
  351. //write_cmd[3] = read_time_data[2]; //hour
  352. //write_cmd[4] = read_time_data[3]; //day
  353. //write_cmd[5] = read_time_data[4]; //week
  354. //write_cmd[6] = read_time_data[5]; //mon
  355. //write_cmd[7] = read_time_data[6]; //year
  356. }
  357. ret = i2c_write(i2c_dev, write_cmd, 8, rtc_slaver_addr);
  358. if (ret != 0)
  359. {
  360. printk("i2c write ERR\n");
  361. return;
  362. }
  363. k_msleep(1);
  364. ret = i2c_write_read(i2c_dev, rtc_slaver_addr, write_cmd, 1, read_cmd, 7);
  365. if (ret != 0)
  366. {
  367. printk("i2c_write_read ERR\n");
  368. return;
  369. }
  370. printk("y:%x, mon:%x, week:%x, d:%x, h:%x, min:%x, sec:%x\n",
  371. read_cmd[6], read_cmd[5], read_cmd[4], read_cmd[3], read_cmd[2], read_cmd[1], read_cmd[0]);
  372. printk("_sd8563_set_time exit\n");
  373. #endif
  374. }
  375. static void _sd8563_read_time(const struct device *i2c_dev, bool is_uart_send)
  376. {
  377. #if 1
  378. uint8_t i, check_sum = 0x52;
  379. uint8_t write_cmd[1] = {0x02};
  380. //static uint8_t read_time_data[7] = {0};
  381. int ret = 0;
  382. //printk("_sd8563_read_time\n");
  383. ret = i2c_write_read(i2c_dev, rtc_slaver_addr, write_cmd, 1, read_time_data, 7);
  384. //ret = i2c_burst_read(i2c_dev, rtc_slaver_addr, 0x02, read_cmd, 3);
  385. //ret = i2c_read(i2c_dev, read_time_data, 7, rtc_slaver_addr);
  386. if (ret != 0)
  387. {
  388. printk("i2c_write_read ERR\n");
  389. }
  390. read_time_data[0] = read_time_data[0] & 0x7F; //bit7:0SF/
  391. read_time_data[5] = read_time_data[5] & 0x7F; //bit7:C/century
  392. if (is_uart_send == false)
  393. {
  394. return;
  395. }
  396. //uart2 send data start ==============================================//
  397. uart2_poll_out_ch(0x5A); //报文表头
  398. uart2_poll_out_ch(0x54);
  399. for (i = 0; i < 7; i++)
  400. {
  401. read_time_data[i] = (read_time_data[i] / 16) * 10 + read_time_data[i] % 16; //DEC TO BCD CODE
  402. check_sum += read_time_data[i];
  403. uart2_poll_out_ch(read_time_data[i]);
  404. }
  405. uart2_poll_out_ch(check_sum); //checksum
  406. //uart2 send data end ==============================================//
  407. //printk("y:20%d, mon:%d, week:%d, d:%d, h:%d, min:%d, sec:%d\n",
  408. // read_time_data[6], read_time_data[5], read_time_data[4], read_time_data[3], read_time_data[2], read_time_data[1], read_time_data[0]);
  409. #endif
  410. }
  411. static void _sd8563_init_work(struct k_work *work)
  412. {
  413. struct acts_timer_data *external_rtc = &timer_acts_ddata;
  414. printk("sd8563 init work\n");
  415. external_rtc->inited = true;
  416. bInitTimeData = false;
  417. if (_sd8563_close_write_protection(external_rtc->i2c_dev) == 1)
  418. {
  419. //k_msleep(2);
  420. _sd8563_set_time(external_rtc->i2c_dev, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF);
  421. //k_msleep(2);
  422. _sd8563_open_write_protection(external_rtc->i2c_dev);
  423. }
  424. #if 0
  425. uint8_t i;
  426. for (i=0; i < 20; i++)
  427. {
  428. k_msleep(1000);
  429. _sd8563_read_time(external_rtc->i2c_dev, 0);
  430. }
  431. #endif
  432. htimer_read(1000); //1000ms = 1s
  433. printk("sd8563 init work exit\n");
  434. }
  435. static int _sd8563_acts_init(const struct device *dev)
  436. {
  437. struct acts_timer_data *external_rtc = dev->data;
  438. printk("sd8563 acts init\n");
  439. #if 1
  440. external_rtc->this_dev = (struct device *)dev;
  441. external_rtc->i2c_dev = (struct device *)device_get_binding(CONFIG_SD8563_I2C_NAME);
  442. if (!external_rtc->i2c_dev) {
  443. printk("can not access right i2c device\n");
  444. return -1;
  445. }
  446. external_rtc->inited = false;
  447. k_work_init(&external_rtc->init_timer, _sd8563_init_work);
  448. #ifdef CONFIG_USED_TP_WORK_QUEUE
  449. k_work_queue_start(&timer_drv_q, timer_work_q_stack, K_THREAD_STACK_SIZEOF(timer_work_q_stack), 7, NULL);
  450. k_work_submit_to_queue(&timer_drv_q, &external_rtc->init_timer);
  451. #else
  452. k_work_submit(&external_rtc->init_timer);
  453. #endif
  454. #endif
  455. printk("sd8563 acts init exit\n");
  456. return 0;
  457. }
  458. #ifdef CONFIG_PM_DEVICE
  459. static void _sd8563_suspend(const struct device *dev)
  460. {
  461. //struct acts_timer_data *external_rtc = (struct acts_timer_data *)dev->data;
  462. printk("sd8563 suspend\n");
  463. hrtimer_stop(&g_rtc_ht_read);
  464. }
  465. static void _sd8563_resume(const struct device *dev)
  466. {
  467. struct acts_timer_data *external_rtc = (struct acts_timer_data *)dev->data;
  468. external_rtc->i2c_dev = (struct device *)device_get_binding(CONFIG_SD8563_I2C_NAME);
  469. if (!external_rtc->i2c_dev) {
  470. printk("can not access right i2c device\n");
  471. return;
  472. }
  473. external_rtc->inited = false;
  474. k_work_init(&external_rtc->init_timer, _sd8563_init_work);
  475. printk("sd8563 resume\n");
  476. #ifdef CONFIG_USED_TP_WORK_QUEUE
  477. k_work_submit_to_queue(&tp_drv_q, &external_rtc->init_timer);
  478. #else
  479. k_work_submit(&external_rtc->init_timer);
  480. #endif
  481. }
  482. static int _sd8563_pm_control(const struct device *dev, enum pm_device_action action)
  483. {
  484. int ret = 0;
  485. //printk("sd8563 pm control\n");
  486. switch (action) {
  487. case PM_DEVICE_ACTION_SUSPEND:
  488. break;
  489. case PM_DEVICE_ACTION_RESUME:
  490. break;
  491. case PM_DEVICE_ACTION_EARLY_SUSPEND:
  492. _sd8563_suspend(dev);
  493. break;
  494. case PM_DEVICE_ACTION_LATE_RESUME:
  495. _sd8563_resume(dev);
  496. break;
  497. default:
  498. break;
  499. }
  500. return ret;
  501. }
  502. #else /* CONFIG_PM_DEVICE */
  503. static int _sd8563_pm_control(const struct device *dev, uint32_t ctrl_command,
  504. void *context, device_pm_cb cb, void *arg)
  505. {
  506. }
  507. #endif
  508. #if IS_ENABLED(CONFIG_SD8563)
  509. DEVICE_DEFINE(sd8563, CONFIG_SD8563_DEV_NAME, _sd8563_acts_init,
  510. _sd8563_pm_control, &timer_acts_ddata, NULL, POST_KERNEL,
  511. 50, NULL);
  512. #endif