ssp_dev.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714
  1. /*
  2. * Copyright (C) 2012, Samsung Electronics Co. Ltd. All Rights Reserved.
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation; either version 2 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. */
  15. #include "ssp.h"
  16. #ifdef CONFIG_OF
  17. #include <linux/of_gpio.h>
  18. #endif
  19. #if SSP_SEC_DEBUG
  20. #include <mach/sec_debug.h>
  21. #endif
  22. #ifdef CONFIG_HAS_EARLYSUSPEND
  23. static void ssp_early_suspend(struct early_suspend *handler);
  24. static void ssp_late_resume(struct early_suspend *handler);
  25. #endif
  26. #ifdef CONFIG_SEC_HESTIA_PROJECT
  27. #define NORMAL_SENSOR_STATE 0x23ff9f
  28. #else
  29. #define NORMAL_SENSOR_STATE 0x3FEFF
  30. #endif
  31. void ssp_enable(struct ssp_data *data, bool enable)
  32. {
  33. pr_info("[SSP] %s, enable = %d, old enable = %d\n",
  34. __func__, enable, data->bSspShutdown);
  35. if (enable && data->bSspShutdown) {
  36. data->bSspShutdown = false;
  37. enable_irq(data->iIrq);
  38. enable_irq_wake(data->iIrq);
  39. } else if (!enable && !data->bSspShutdown) {
  40. data->bSspShutdown = true;
  41. disable_irq(data->iIrq);
  42. disable_irq_wake(data->iIrq);
  43. } else
  44. pr_err("[SSP] %s, enable error\n", __func__);
  45. }
  46. /************************************************************************/
  47. /* interrupt happened due to transition/change of SSP MCU */
  48. /************************************************************************/
  49. static irqreturn_t sensordata_irq_thread_fn(int iIrq, void *dev_id)
  50. {
  51. struct ssp_data *data = dev_id;
  52. if(gpio_get_value(data->mcu_int1)) {
  53. pr_info("[SSP] MCU int HIGH");
  54. return IRQ_HANDLED;
  55. }
  56. select_irq_msg(data);
  57. data->uIrqCnt++;
  58. return IRQ_HANDLED;
  59. }
  60. /*************************************************************************/
  61. /* initialize sensor hub */
  62. /*************************************************************************/
  63. static void initialize_variable(struct ssp_data *data)
  64. {
  65. int iSensorIndex;
  66. for (iSensorIndex = 0; iSensorIndex < SENSOR_MAX; iSensorIndex++) {
  67. data->adDelayBuf[iSensorIndex] = DEFUALT_POLLING_DELAY;
  68. data->batchLatencyBuf[iSensorIndex] = 0;
  69. data->batchOptBuf[iSensorIndex] = 0;
  70. data->aiCheckStatus[iSensorIndex] = INITIALIZATION_STATE;
  71. }
  72. atomic_set(&data->aSensorEnable, 0);
  73. data->iLibraryLength = 0;
  74. data->uSensorState = NORMAL_SENSOR_STATE;
  75. data->uFactoryProxAvg[0] = 0;
  76. data->uMagCntlRegData = 1;
  77. data->uResetCnt = 0;
  78. data->uTimeOutCnt = 0;
  79. data->uComFailCnt = 0;
  80. data->uIrqCnt = 0;
  81. data->bSspShutdown = true;
  82. data->bProximityRawEnabled = false;
  83. data->bGeomagneticRawEnabled = false;
  84. data->bBarcodeEnabled = false;
  85. data->bAccelAlert = false;
  86. data->bTimeSyncing = true;
  87. data->accelcal.x = 0;
  88. data->accelcal.y = 0;
  89. data->accelcal.z = 0;
  90. data->gyrocal.x = 0;
  91. data->gyrocal.y = 0;
  92. data->gyrocal.z = 0;
  93. data->magoffset.x = 0;
  94. data->magoffset.y = 0;
  95. data->magoffset.z = 0;
  96. data->iPressureCal = 0;
  97. data->uProxCanc = 0;
  98. data->uProxHiThresh = 0;
  99. data->uProxLoThresh = 0;
  100. data->uGyroDps = GYROSCOPE_DPS500;
  101. data->uIr_Current = 0;
  102. data->mcu_device = NULL;
  103. data->acc_device = NULL;
  104. data->gyro_device = NULL;
  105. data->mag_device = NULL;
  106. data->prs_device = NULL;
  107. data->prox_device = NULL;
  108. data->light_device = NULL;
  109. #if defined(CONFIG_SENSORS_SSP_TMG399X) || defined(CONFIG_SENSORS_SSP_MAX88921) || \
  110. defined(CONFIG_SENSORS_SSP_MAX88920)
  111. data->ges_device = NULL;
  112. #endif
  113. #ifdef CONFIG_SENSORS_SSP_UVIS25
  114. data->uv_device = NULL;
  115. #endif
  116. data->voice_device = NULL;
  117. #if SSP_SEC_DEBUG
  118. data->bMcuDumpMode = sec_debug_is_enabled();
  119. #endif
  120. INIT_LIST_HEAD(&data->pending_list);
  121. data->step_count_total = 0;
  122. data->sealevelpressure = 0;
  123. initialize_function_pointer(data);
  124. }
  125. int initialize_mcu(struct ssp_data *data)
  126. {
  127. int iRet = 0;
  128. clean_pending_list(data);
  129. iRet = get_chipid(data);
  130. pr_info("[SSP] MCU device ID = %d, reading ID = %d\n", DEVICE_ID, iRet);
  131. if (iRet != DEVICE_ID) {
  132. if (iRet < 0) {
  133. pr_err("[SSP]: %s - MCU is not working : 0x%x\n",
  134. __func__, iRet);
  135. } else {
  136. pr_err("[SSP]: %s - MCU identification failed\n",
  137. __func__);
  138. iRet = -ENODEV;
  139. }
  140. goto out;
  141. }
  142. iRet = set_sensor_position(data);
  143. if (iRet < 0) {
  144. pr_err("[SSP]: %s - set_sensor_position failed\n", __func__);
  145. goto out;
  146. }
  147. iRet = get_fuserom_data(data);
  148. if (iRet < 0)
  149. pr_err("[SSP]: %s - get_fuserom_data failed\n", __func__);
  150. data->uSensorState = get_sensor_scanning_info(data);
  151. if (data->uSensorState == 0) {
  152. pr_err("[SSP]: %s - get_sensor_scanning_info failed\n",
  153. __func__);
  154. iRet = ERROR;
  155. goto out;
  156. }
  157. data->uCurFirmRev = get_firmware_rev(data);
  158. pr_info("[SSP] MCU Firm Rev : New = %8u\n",
  159. data->uCurFirmRev);
  160. iRet = ssp_send_cmd(data, MSG2SSP_AP_MCU_DUMP_CHECK, 0);
  161. out:
  162. return iRet;
  163. }
  164. static int initialize_irq(struct ssp_data *data)
  165. {
  166. int iRet, iIrq;
  167. iIrq = gpio_to_irq(data->mcu_int1);
  168. pr_info("[SSP]: requesting IRQ %d\n", iIrq);
  169. iRet = request_threaded_irq(iIrq, NULL, sensordata_irq_thread_fn,
  170. IRQF_TRIGGER_FALLING|IRQF_ONESHOT, "SSP_Int", data);
  171. if (iRet < 0) {
  172. pr_err("[SSP]: %s - request_irq(%d) failed for gpio %d (%d)\n",
  173. __func__, iIrq, iIrq, iRet);
  174. goto err_request_irq;
  175. }
  176. /* start with interrupts disabled */
  177. data->iIrq = iIrq;
  178. disable_irq(data->iIrq);
  179. return 0;
  180. err_request_irq:
  181. gpio_free(data->mcu_int1);
  182. return iRet;
  183. }
  184. static void work_function_firmware_update(struct work_struct *work)
  185. {
  186. struct ssp_data *data = container_of((struct delayed_work *)work,
  187. struct ssp_data, work_firmware);
  188. int iRet = 0;
  189. pr_info("[SSP] : %s\n", __func__);
  190. iRet = forced_to_download_binary(data, KERNEL_BINARY);
  191. if (iRet < 0) {
  192. ssp_dbg("[SSP]: %s - forced_to_download_binary failed!\n",
  193. __func__);
  194. data->uSensorState = 0;
  195. return;
  196. }
  197. queue_refresh_task(data, SSP_SW_RESET_TIME);
  198. }
  199. static int ssp_parse_dt(struct device *dev,
  200. struct ssp_data *data)
  201. {
  202. struct device_node *np = dev->of_node;
  203. enum of_gpio_flags flags;
  204. int errorno = 0;
  205. data->mcu_int1 = of_get_named_gpio_flags(np, "ssp,mcu_int1-gpio",
  206. 0, &flags);
  207. if (data->mcu_int1 < 0) {
  208. errorno = data->mcu_int1;
  209. goto dt_exit;
  210. }
  211. data->mcu_int2 = of_get_named_gpio_flags(np, "ssp,mcu_int2-gpio",
  212. 0, &flags);
  213. if (data->mcu_int2 < 0) {
  214. errorno = data->mcu_int2;
  215. goto dt_exit;
  216. }
  217. data->ap_int = of_get_named_gpio_flags(np, "ssp,ap_int-gpio",
  218. 0, &flags);
  219. if (data->ap_int < 0) {
  220. errorno = data->ap_int;
  221. goto dt_exit;
  222. }
  223. #if defined(CONFIG_MACH_KLTE_JPN)
  224. #if defined(CONFIG_MACH_KLTE_MAX77828_JPN)
  225. data->rst = of_get_named_gpio_flags(np, "ssp,rst-gpio",
  226. 0, &flags);
  227. #else
  228. of_property_read_u32(np, "ssp,rst-gpio", &data->rst);
  229. #endif
  230. #else
  231. data->rst = of_get_named_gpio_flags(np, "ssp,rst-gpio",
  232. 0, &flags);
  233. #endif
  234. if (data->rst < 0) {
  235. errorno = data->rst ;
  236. goto dt_exit;
  237. }
  238. if (of_property_read_u32(np, "ssp,acc-position", &data->accel_position))
  239. data->accel_position = 0;
  240. if (of_property_read_u32(np, "ssp,mag-position", &data->mag_position))
  241. data->mag_position = 0;
  242. if (of_property_read_u32(np, "ssp,ap-rev", &data->ap_rev))
  243. data->ap_rev = 0;
  244. errorno = gpio_request(data->mcu_int1, "mpu_ap_int1");
  245. if (errorno) {
  246. pr_err("[SSP] failed to request MCU_INT2 for SSP\n");
  247. goto dt_exit;
  248. }
  249. errorno = gpio_direction_input(data->mcu_int1);
  250. if (errorno) {
  251. pr_err("[SSP] failed to set mcu_int1 as input\n");
  252. goto dt_exit;
  253. }
  254. errorno = gpio_request(data->mcu_int2, "MCU_INT2");
  255. if (errorno) {
  256. pr_err("[SSP] failed to request MCU_INT2 for SSP\n");
  257. goto dt_exit;
  258. }
  259. gpio_direction_input(data->mcu_int2);
  260. errorno = gpio_request(data->ap_int, "AP_MCU_INT");
  261. if (errorno) {
  262. pr_err("[SSP] failed to request AP_INT for SSP\n");
  263. goto dt_exit;
  264. }
  265. gpio_direction_output(data->ap_int, 1);
  266. errorno = gpio_request(data->rst, "MCU_RST");
  267. if (errorno) {
  268. pr_err("[SSP] failed to request MCU_RST for SSP\n");
  269. goto dt_exit;
  270. }
  271. gpio_direction_output(data->rst, 1);
  272. data->reg_hub = devm_regulator_get(dev, "hub_vreg");
  273. if (IS_ERR(data->reg_hub)) {
  274. pr_err("[SSP] could not get hub_vreg, %ld\n",
  275. PTR_ERR(data->reg_hub));
  276. } else {
  277. regulator_enable(data->reg_hub);
  278. }
  279. data->reg_sns= devm_regulator_get(dev, "psns_vreg");
  280. if (IS_ERR(data->reg_hub)) {
  281. pr_err("[SSP] could not get psns_vreg, %ld\n",
  282. PTR_ERR(data->reg_sns));
  283. } else {
  284. regulator_enable(data->reg_sns);
  285. }
  286. dt_exit:
  287. return errorno;
  288. }
  289. static int ssp_probe(struct spi_device *spi_dev)
  290. {
  291. int iRet = 0;
  292. struct ssp_data *data;
  293. struct ssp_platform_data *pdata;
  294. pr_info("[SSP] %s\n", __func__);
  295. if (poweroff_charging == 1 || boot_mode_recovery == 1) {
  296. pr_err("[SSP] probe exit : lpm %d, recovery %d\n",
  297. poweroff_charging, boot_mode_recovery);
  298. return -ENODEV;
  299. }
  300. data = kzalloc(sizeof(*data), GFP_KERNEL);
  301. if (data == NULL) {
  302. pr_err("[SSP]: %s - failed to allocate memory for data\n",
  303. __func__);
  304. iRet = -ENOMEM;
  305. goto exit;
  306. }
  307. if (spi_dev->dev.of_node) {
  308. iRet = ssp_parse_dt(&spi_dev->dev, data);
  309. if (iRet) {
  310. pr_err("[SSP]: %s - Failed to parse DT\n", __func__);
  311. goto err_setup;
  312. }
  313. data->ssp_changes = SSP_MCU_L5; /* K330, MPU L5*/
  314. } else {
  315. pdata = spi_dev->dev.platform_data;
  316. if (pdata == NULL) {
  317. pr_err("[SSP]: %s - platform_data is null\n", __func__);
  318. iRet = -ENOMEM;
  319. goto err_setup;
  320. }
  321. data->wakeup_mcu = pdata->wakeup_mcu;
  322. data->check_mcu_ready = pdata->check_mcu_ready;
  323. data->check_mcu_busy = pdata->check_mcu_busy;
  324. data->set_mcu_reset = pdata->set_mcu_reset;
  325. data->read_chg = pdata->read_chg;
  326. /* AP system_rev */
  327. if (pdata->check_ap_rev)
  328. data->ap_rev = pdata->check_ap_rev();
  329. else
  330. data->ap_rev = 0;
  331. /* For changed devices */
  332. if (pdata->check_changes)
  333. data->ssp_changes = pdata->check_changes();
  334. else
  335. data->ssp_changes = SSP_MCU_L5; /* K330, MPU L5*/
  336. /* Get sensor positions */
  337. if (pdata->get_positions)
  338. pdata->get_positions(&data->accel_position,
  339. &data->mag_position);
  340. else if (spi_dev->dev.of_node == NULL) {
  341. data->accel_position = 0;
  342. data->mag_position = 0;
  343. }
  344. }
  345. spi_dev->mode = SPI_MODE_1;
  346. if (spi_setup(spi_dev)) {
  347. pr_err("failed to setup spi for ssp_spi\n");
  348. goto err_setup;
  349. }
  350. data->bProbeIsDone = false;
  351. data->fw_dl_state = FW_DL_STATE_NONE;
  352. data->spi = spi_dev;
  353. spi_set_drvdata(spi_dev, data);
  354. #ifdef CONFIG_SENSORS_SSP_SHTC1
  355. mutex_init(&data->cp_temp_adc_lock);
  356. mutex_init(&data->bulk_temp_read_lock);
  357. #endif
  358. mutex_init(&data->comm_mutex);
  359. mutex_init(&data->pending_mutex);
  360. if (((data->wakeup_mcu == NULL)
  361. || (data->check_mcu_ready == NULL)
  362. || (data->check_mcu_busy == NULL)
  363. || (data->set_mcu_reset == NULL)
  364. || (data->read_chg == NULL))
  365. && (spi_dev->dev.of_node == NULL)) {
  366. pr_err("[SSP]: %s - function callback is null\n", __func__);
  367. iRet = -EIO;
  368. goto err_reset_null;
  369. }
  370. pr_info("\n#####################################################\n");
  371. INIT_DELAYED_WORK(&data->work_firmware, work_function_firmware_update);
  372. wake_lock_init(&data->ssp_wake_lock,
  373. WAKE_LOCK_SUSPEND, "ssp_wake_lock");
  374. iRet = initialize_input_dev(data);
  375. if (iRet < 0) {
  376. pr_err("[SSP]: %s - could not create input device\n", __func__);
  377. goto err_input_register_device;
  378. }
  379. iRet = initialize_debug_timer(data);
  380. if (iRet < 0) {
  381. pr_err("[SSP]: %s - could not create workqueue\n", __func__);
  382. goto err_create_workqueue;
  383. }
  384. iRet = initialize_irq(data);
  385. if (iRet < 0) {
  386. pr_err("[SSP]: %s - could not create irq\n", __func__);
  387. goto err_setup_irq;
  388. }
  389. iRet = initialize_sysfs(data);
  390. if (iRet < 0) {
  391. pr_err("[SSP]: %s - could not create sysfs\n", __func__);
  392. goto err_sysfs_create;
  393. }
  394. iRet = initialize_event_symlink(data);
  395. if (iRet < 0) {
  396. pr_err("[SSP]: %s - could not create symlink\n", __func__);
  397. goto err_symlink_create;
  398. }
  399. initialize_variable(data);
  400. #ifdef CONFIG_SENSORS_SSP_SENSORHUB
  401. /* init sensorhub device */
  402. iRet = ssp_sensorhub_initialize(data);
  403. if (iRet < 0) {
  404. pr_err("%s: ssp_sensorhub_initialize err(%d)", __func__, iRet);
  405. ssp_sensorhub_remove(data);
  406. }
  407. #endif
  408. ssp_enable(data, true);
  409. /* check boot loader binary */
  410. data->fw_dl_state = check_fwbl(data);
  411. if (data->fw_dl_state == FW_DL_STATE_NONE) {
  412. iRet = initialize_mcu(data);
  413. if (iRet == ERROR) {
  414. toggle_mcu_reset(data);
  415. } else if (iRet < ERROR) {
  416. pr_err("[SSP]: %s - initialize_mcu failed\n", __func__);
  417. goto err_read_reg;
  418. }
  419. }
  420. #ifdef CONFIG_HAS_EARLYSUSPEND
  421. data->early_suspend.suspend = ssp_early_suspend;
  422. data->early_suspend.resume = ssp_late_resume;
  423. register_early_suspend(&data->early_suspend);
  424. #endif
  425. pr_info("[SSP]: %s - probe success!\n", __func__);
  426. enable_debug_timer(data);
  427. iRet = 0;
  428. if (data->fw_dl_state == FW_DL_STATE_NEED_TO_SCHEDULE) {
  429. pr_info("[SSP]: Firmware update is scheduled\n");
  430. schedule_delayed_work(&data->work_firmware,
  431. msecs_to_jiffies(1000));
  432. data->fw_dl_state = FW_DL_STATE_SCHEDULED;
  433. } else if (data->fw_dl_state == FW_DL_STATE_FAIL)
  434. data->bSspShutdown = true;
  435. data->bProbeIsDone = true;
  436. goto exit;
  437. err_read_reg:
  438. err_symlink_create:
  439. remove_sysfs(data);
  440. err_sysfs_create:
  441. free_irq(data->iIrq, data);
  442. gpio_free(data->mcu_int1);
  443. err_setup_irq:
  444. destroy_workqueue(data->debug_wq);
  445. err_create_workqueue:
  446. remove_input_dev(data);
  447. err_input_register_device:
  448. wake_lock_destroy(&data->ssp_wake_lock);
  449. err_reset_null:
  450. #ifdef CONFIG_SENSORS_SSP_SHTC1
  451. mutex_destroy(&data->cp_temp_adc_lock);
  452. mutex_destroy(&data->bulk_temp_read_lock);
  453. #endif
  454. mutex_destroy(&data->comm_mutex);
  455. mutex_destroy(&data->pending_mutex);
  456. err_setup:
  457. kfree(data);
  458. pr_err("[SSP]: %s - probe failed!\n", __func__);
  459. exit:
  460. pr_info("#####################################################\n\n");
  461. return iRet;
  462. }
  463. static void ssp_shutdown(struct spi_device *spi_dev)
  464. {
  465. struct ssp_data *data = spi_get_drvdata(spi_dev);
  466. func_dbg();
  467. if (data->bProbeIsDone == false)
  468. goto exit;
  469. if (data->fw_dl_state >= FW_DL_STATE_SCHEDULED &&
  470. data->fw_dl_state < FW_DL_STATE_DONE) {
  471. pr_err("%s, cancel_delayed_work_sync state = %d\n",
  472. __func__, data->fw_dl_state);
  473. cancel_delayed_work_sync(&data->work_firmware);
  474. }
  475. disable_debug_timer(data);
  476. if (SUCCESS != ssp_send_cmd(data, MSG2SSP_AP_STATUS_SHUTDOWN, 0))
  477. pr_err("[SSP]: %s MSG2SSP_AP_STATUS_SHUTDOWN failed\n",
  478. __func__);
  479. ssp_enable(data, false);
  480. clean_pending_list(data);
  481. #ifdef CONFIG_HAS_EARLYSUSPEND
  482. unregister_early_suspend(&data->early_suspend);
  483. #endif
  484. free_irq(data->iIrq, data);
  485. gpio_free(data->mcu_int1);
  486. remove_event_symlink(data);
  487. remove_sysfs(data);
  488. remove_input_dev(data);
  489. #ifdef CONFIG_SENSORS_SSP_SENSORHUB
  490. ssp_sensorhub_remove(data);
  491. #endif
  492. cancel_delayed_work_sync(&data->work_refresh);
  493. destroy_workqueue(data->debug_wq);
  494. wake_lock_destroy(&data->ssp_wake_lock);
  495. #ifdef CONFIG_SENSORS_SSP_SHTC1
  496. mutex_destroy(&data->cp_temp_adc_lock);
  497. mutex_destroy(&data->bulk_temp_read_lock);
  498. #endif
  499. mutex_destroy(&data->comm_mutex);
  500. mutex_destroy(&data->pending_mutex);
  501. toggle_mcu_reset(data);
  502. /* gpio_set_value_cansleep(data->rst, 0); */
  503. pr_info("[SSP]: %s done\n", __func__);
  504. exit:
  505. kfree(data);
  506. }
  507. #ifdef CONFIG_HAS_EARLYSUSPEND
  508. static void ssp_early_suspend(struct early_suspend *handler)
  509. {
  510. struct ssp_data *data;
  511. data = container_of(handler, struct ssp_data, early_suspend);
  512. func_dbg();
  513. disable_debug_timer(data);
  514. #ifdef CONFIG_SENSORS_SSP_SENSORHUB
  515. /* give notice to user that AP goes to sleep */
  516. ssp_sensorhub_report_notice(data, MSG2SSP_AP_STATUS_SLEEP);
  517. ssp_sleep_mode(data);
  518. data->uLastAPState = MSG2SSP_AP_STATUS_SLEEP;
  519. #else
  520. if (atomic_read(&data->aSensorEnable) > 0)
  521. ssp_sleep_mode(data);
  522. #endif
  523. }
  524. static void ssp_late_resume(struct early_suspend *handler)
  525. {
  526. struct ssp_data *data;
  527. data = container_of(handler, struct ssp_data, early_suspend);
  528. func_dbg();
  529. enable_debug_timer(data);
  530. #ifdef CONFIG_SENSORS_SSP_SENSORHUB
  531. /* give notice to user that AP goes to sleep */
  532. ssp_sensorhub_report_notice(data, MSG2SSP_AP_STATUS_WAKEUP);
  533. ssp_resume_mode(data);
  534. data->uLastAPState = MSG2SSP_AP_STATUS_WAKEUP;
  535. #else
  536. if (atomic_read(&data->aSensorEnable) > 0)
  537. ssp_resume_mode(data);
  538. #endif
  539. }
  540. #else /* CONFIG_HAS_EARLYSUSPEND */
  541. static int ssp_suspend(struct device *dev)
  542. {
  543. struct spi_device *spi_dev = to_spi_device(dev);
  544. struct ssp_data *data = spi_get_drvdata(spi_dev);
  545. func_dbg();
  546. data->uLastResumeState = MSG2SSP_AP_STATUS_SUSPEND;
  547. disable_debug_timer(data);
  548. if (SUCCESS != ssp_send_cmd(data, MSG2SSP_AP_STATUS_SUSPEND, 0))
  549. pr_err("[SSP]: %s MSG2SSP_AP_STATUS_SUSPEND failed\n",
  550. __func__);
  551. data->bTimeSyncing = false;
  552. disable_irq(data->iIrq);
  553. return 0;
  554. }
  555. static int ssp_resume(struct device *dev)
  556. {
  557. struct spi_device *spi_dev = to_spi_device(dev);
  558. struct ssp_data *data = spi_get_drvdata(spi_dev);
  559. enable_irq(data->iIrq);
  560. func_dbg();
  561. enable_debug_timer(data);
  562. if (SUCCESS != ssp_send_cmd(data, MSG2SSP_AP_STATUS_RESUME, 0))
  563. pr_err("[SSP]: %s MSG2SSP_AP_STATUS_RESUME failed\n",
  564. __func__);
  565. data->uLastResumeState = MSG2SSP_AP_STATUS_RESUME;
  566. return 0;
  567. }
  568. static const struct dev_pm_ops ssp_pm_ops = {
  569. .suspend = ssp_suspend,
  570. .resume = ssp_resume
  571. };
  572. #endif /* CONFIG_HAS_EARLYSUSPEND */
  573. static const struct spi_device_id ssp_id[] = {
  574. {"ssp", 0},
  575. {}
  576. };
  577. MODULE_DEVICE_TABLE(spi, ssp_id);
  578. #ifdef CONFIG_OF
  579. static struct of_device_id ssp_match_table[] = {
  580. { .compatible = "ssp,STM32F",},
  581. {},
  582. };
  583. #else
  584. #define mpu6500_match_table NULL
  585. #endif
  586. static struct spi_driver ssp_driver = {
  587. .probe = ssp_probe,
  588. .shutdown = ssp_shutdown,
  589. .id_table = ssp_id,
  590. .driver = {
  591. #ifndef CONFIG_HAS_EARLYSUSPEND
  592. .pm = &ssp_pm_ops,
  593. #endif
  594. .owner = THIS_MODULE,
  595. .name = "ssp",
  596. .of_match_table = ssp_match_table
  597. },
  598. };
  599. module_spi_driver(ssp_driver);
  600. MODULE_DESCRIPTION("ssp driver");
  601. MODULE_AUTHOR("Samsung Electronics");
  602. MODULE_LICENSE("GPL");