ssp_dev.c 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855
  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. #define NORMAL_SENSOR_STATE_K 0x3FEFF
  27. #define GES_LDO_ON 1
  28. #define GES_LDO_OFF 0
  29. #ifdef CONFIG_DUAL_LCD
  30. int flip_status;
  31. static struct ssp_data *ssp_data_check = NULL;
  32. void magnetic_set_ssp_info(struct ssp_data *data)
  33. {
  34. if (data != NULL)
  35. ssp_data_check = data;
  36. else
  37. pr_info("%s : ssp info is null\n", __func__);
  38. }
  39. static struct ssp_data *magnetic_get_ssp_info(void)
  40. {
  41. return ssp_data_check;
  42. }
  43. void samsung_switching_ssp(int flip)
  44. {
  45. struct ssp_data *data;
  46. data = magnetic_get_ssp_info();
  47. if (data == NULL){
  48. pr_err("[SSP] %s: ssp info is null\n", __func__);
  49. return;
  50. }
  51. flip_status = flip;
  52. if ((atomic_read(&data->aSensorEnable) & (1 << GEOMAGNETIC_SENSOR))
  53. || (atomic_read(&data->aSensorEnable) & (1 << ORIENTATION_SENSOR))
  54. || (atomic_read(&data->aSensorEnable) & (1 << ROTATION_VECTOR))){
  55. /*flip_status 0:open, 1:close*/
  56. set_magnetic_cal_with_folder_state(data, flip_status);
  57. pr_info("[SSP] %s : Folder is %sed now.\n", __func__,
  58. flip_status ? "clos":"open");
  59. }
  60. }
  61. EXPORT_SYMBOL(samsung_switching_ssp);
  62. int ssp_get_flip_status(void)
  63. {
  64. return flip_status;
  65. }
  66. #endif
  67. void ssp_enable(struct ssp_data *data, bool enable)
  68. {
  69. pr_info("[SSP] %s, enable = %d, old enable = %d\n",
  70. __func__, enable, data->bSspShutdown);
  71. if (enable && data->bSspShutdown) {
  72. data->bSspShutdown = false;
  73. enable_irq(data->iIrq);
  74. enable_irq_wake(data->iIrq);
  75. } else if (!enable && !data->bSspShutdown) {
  76. data->bSspShutdown = true;
  77. disable_irq(data->iIrq);
  78. disable_irq_wake(data->iIrq);
  79. } else
  80. pr_err("[SSP] %s, enable error\n", __func__);
  81. }
  82. /************************************************************************/
  83. /* interrupt happened due to transition/change of SSP MCU */
  84. /************************************************************************/
  85. static irqreturn_t sensordata_irq_thread_fn(int iIrq, void *dev_id)
  86. {
  87. struct ssp_data *data = dev_id;
  88. if(gpio_get_value(data->mcu_int1)) {
  89. pr_info("[SSP] MCU int HIGH");
  90. return IRQ_HANDLED;
  91. }
  92. select_irq_msg(data);
  93. data->uIrqCnt++;
  94. return IRQ_HANDLED;
  95. }
  96. /*************************************************************************/
  97. /* initialize sensor hub */
  98. /*************************************************************************/
  99. static void initialize_variable(struct ssp_data *data)
  100. {
  101. int iSensorIndex;
  102. for (iSensorIndex = 0; iSensorIndex < SENSOR_MAX; iSensorIndex++) {
  103. data->adDelayBuf[iSensorIndex] = DEFUALT_POLLING_DELAY;
  104. data->batchLatencyBuf[iSensorIndex] = 0;
  105. data->batchOptBuf[iSensorIndex] = 0;
  106. data->aiCheckStatus[iSensorIndex] = INITIALIZATION_STATE;
  107. }
  108. atomic_set(&data->aSensorEnable, 0);
  109. data->iLibraryLength = 0;
  110. data->uSensorState = NORMAL_SENSOR_STATE_K;
  111. data->uFactoryProxAvg[0] = 0;
  112. data->uMagCntlRegData = 1;
  113. data->uResetCnt = 0;
  114. data->uTimeOutCnt = 0;
  115. data->uComFailCnt = 0;
  116. data->uIrqCnt = 0;
  117. data->bSspShutdown = true;
  118. data->bProximityRawEnabled = false;
  119. data->bGeomagneticRawEnabled = false;
  120. data->bBarcodeEnabled = false;
  121. data->bAccelAlert = false;
  122. data->bTimeSyncing = true;
  123. data->accelcal.x = 0;
  124. data->accelcal.y = 0;
  125. data->accelcal.z = 0;
  126. data->gyrocal.x = 0;
  127. data->gyrocal.y = 0;
  128. data->gyrocal.z = 0;
  129. data->magoffset.x = 0;
  130. data->magoffset.y = 0;
  131. data->magoffset.z = 0;
  132. data->iPressureCal = 0;
  133. data->uProxCanc = 0;
  134. data->uProxHiThresh = 0;
  135. data->uProxLoThresh = 0;
  136. data->uGyroDps = GYROSCOPE_DPS500;
  137. data->uIr_Current = 0;
  138. data->mcu_device = NULL;
  139. data->acc_device = NULL;
  140. data->gyro_device = NULL;
  141. data->mag_device = NULL;
  142. data->prs_device = NULL;
  143. data->prox_device = NULL;
  144. data->light_device = NULL;
  145. data->ges_device = NULL;
  146. data->voice_device = NULL;
  147. #if SSP_SEC_DEBUG
  148. data->bMcuDumpMode = sec_debug_is_enabled();
  149. #endif
  150. INIT_LIST_HEAD(&data->pending_list);
  151. data->step_count_total = 0;
  152. data->sealevelpressure = 0;
  153. initialize_function_pointer(data);
  154. }
  155. int initialize_mcu(struct ssp_data *data)
  156. {
  157. int iRet = 0;
  158. clean_pending_list(data);
  159. iRet = get_chipid(data);
  160. pr_info("[SSP] MCU device ID = %d, reading ID = %d\n", DEVICE_ID, iRet);
  161. if (iRet != DEVICE_ID) {
  162. if (iRet < 0) {
  163. pr_err("[SSP]: %s - MCU is not working : 0x%x\n",
  164. __func__, iRet);
  165. } else {
  166. pr_err("[SSP]: %s - MCU identification failed\n",
  167. __func__);
  168. iRet = -ENODEV;
  169. }
  170. goto out;
  171. }
  172. iRet = set_sensor_position(data);
  173. if (iRet < 0) {
  174. pr_err("[SSP]: %s - set_sensor_position failed\n", __func__);
  175. goto out;
  176. }
  177. iRet = get_fuserom_data(data);
  178. if (iRet < 0)
  179. pr_err("[SSP]: %s - get_fuserom_data failed\n", __func__);
  180. data->uSensorState = get_sensor_scanning_info(data);
  181. if (data->uSensorState == 0) {
  182. pr_err("[SSP]: %s - get_sensor_scanning_info failed\n",
  183. __func__);
  184. iRet = ERROR;
  185. goto out;
  186. }
  187. data->uCurFirmRev = get_firmware_rev(data);
  188. pr_info("[SSP] MCU Firm Rev : New = %8u\n",
  189. data->uCurFirmRev);
  190. iRet = ssp_send_cmd(data, MSG2SSP_AP_MCU_DUMP_CHECK, 0);
  191. out:
  192. return iRet;
  193. }
  194. static int initialize_irq(struct ssp_data *data)
  195. {
  196. int iRet, iIrq;
  197. iIrq = gpio_to_irq(data->mcu_int1);
  198. pr_info("[SSP]: requesting IRQ %d\n", iIrq);
  199. iRet = request_threaded_irq(iIrq, NULL, sensordata_irq_thread_fn,
  200. IRQF_TRIGGER_FALLING|IRQF_ONESHOT, "SSP_Int", data);
  201. if (iRet < 0) {
  202. pr_err("[SSP]: %s - request_irq(%d) failed for gpio %d (%d)\n",
  203. __func__, iIrq, iIrq, iRet);
  204. goto err_request_irq;
  205. }
  206. /* start with interrupts disabled */
  207. data->iIrq = iIrq;
  208. disable_irq(data->iIrq);
  209. return 0;
  210. err_request_irq:
  211. gpio_free(data->mcu_int1);
  212. return iRet;
  213. }
  214. static void work_function_firmware_update(struct work_struct *work)
  215. {
  216. struct ssp_data *data = container_of((struct delayed_work *)work,
  217. struct ssp_data, work_firmware);
  218. int iRet = 0;
  219. pr_info("[SSP] : %s\n", __func__);
  220. iRet = forced_to_download_binary(data, KERNEL_BINARY);
  221. if (iRet < 0) {
  222. ssp_dbg("[SSP]: %s - forced_to_download_binary failed!\n",
  223. __func__);
  224. data->uSensorState = 0;
  225. return;
  226. }
  227. queue_refresh_task(data, SSP_SW_RESET_TIME);
  228. }
  229. static int ssp_parse_dt(struct device *dev,
  230. struct ssp_data *data)
  231. {
  232. struct device_node *np = dev->of_node;
  233. enum of_gpio_flags flags;
  234. int errorno = 0;
  235. data->mcu_int1 = of_get_named_gpio_flags(np, "ssp,mcu_int1-gpio",
  236. 0, &flags);
  237. if (data->mcu_int1 < 0) {
  238. errorno = data->mcu_int1;
  239. goto dt_exit;
  240. }
  241. data->mcu_int2 = of_get_named_gpio_flags(np, "ssp,mcu_int2-gpio",
  242. 0, &flags);
  243. if (data->mcu_int2 < 0) {
  244. errorno = data->mcu_int2;
  245. goto dt_exit;
  246. }
  247. data->ap_int = of_get_named_gpio_flags(np, "ssp,ap_int-gpio",
  248. 0, &flags);
  249. if (data->ap_int < 0) {
  250. errorno = data->ap_int;
  251. goto dt_exit;
  252. }
  253. #if defined(CONFIG_SEC_PATEK_PROJECT)
  254. if (of_property_read_string(np, "ssp,ges_vdd_1p8",
  255. &data->ges_vdd) < 0)
  256. pr_err("%s - get ges_vdd error\n", __func__);
  257. if (of_property_read_string(np, "ssp,ges_led_3p3",
  258. &data->ges_led) < 0)
  259. pr_err("%s - get ges_led error\n", __func__);
  260. pr_err("%s - get ges_vcc pass\n", __func__);
  261. #endif
  262. #if defined(CONFIG_MACH_KLTE_JPN) || defined(CONFIG_MACH_KACTIVELTE_DCM)
  263. #if defined(CONFIG_MACH_KLTE_MAX77828_JPN)
  264. data->rst = of_get_named_gpio_flags(np, "ssp,rst-gpio",
  265. 0, &flags);
  266. #else
  267. of_property_read_u32(np, "ssp,rst-gpio", &data->rst);
  268. #endif
  269. #else
  270. data->rst = of_get_named_gpio_flags(np, "ssp,rst-gpio",
  271. 0, &flags);
  272. #endif
  273. if (data->rst < 0) {
  274. errorno = data->rst ;
  275. goto dt_exit;
  276. }
  277. if (of_property_read_u32(np, "ssp,acc-position", &data->accel_position))
  278. data->accel_position = 0;
  279. if (of_property_read_u32(np, "ssp,mag-position", &data->mag_position))
  280. data->mag_position = 0;
  281. if (of_property_read_u32(np, "ssp,ap-rev", &data->ap_rev))
  282. data->ap_rev = 0;
  283. errorno = gpio_request(data->mcu_int1, "mpu_ap_int1");
  284. if (errorno) {
  285. pr_err("[SSP] failed to request MCU_INT2 for SSP\n");
  286. goto dt_exit;
  287. }
  288. errorno = gpio_direction_input(data->mcu_int1);
  289. if (errorno) {
  290. pr_err("[SSP] failed to set mcu_int1 as input\n");
  291. goto dt_exit;
  292. }
  293. errorno = gpio_request(data->mcu_int2, "MCU_INT2");
  294. if (errorno) {
  295. pr_err("[SSP] failed to request MCU_INT2 for SSP\n");
  296. goto dt_exit;
  297. }
  298. gpio_direction_input(data->mcu_int2);
  299. errorno = gpio_request(data->ap_int, "AP_MCU_INT");
  300. if (errorno) {
  301. pr_err("[SSP] failed to request AP_INT for SSP\n");
  302. goto dt_exit;
  303. }
  304. gpio_direction_output(data->ap_int, 1);
  305. errorno = gpio_request(data->rst, "MCU_RST");
  306. if (errorno) {
  307. pr_err("[SSP] failed to request MCU_RST for SSP\n");
  308. goto dt_exit;
  309. }
  310. gpio_direction_output(data->rst, 1);
  311. data->reg_hub = devm_regulator_get(dev, "hub_vreg");
  312. if (IS_ERR(data->reg_hub)) {
  313. pr_err("[SSP] could not get hub_vreg, %ld\n",
  314. PTR_ERR(data->reg_hub));
  315. } else {
  316. regulator_enable(data->reg_hub);
  317. }
  318. data->reg_sns= devm_regulator_get(dev, "psns_vreg");
  319. if (IS_ERR(data->reg_hub)) {
  320. pr_err("[SSP] could not get psns_vreg, %ld\n",
  321. PTR_ERR(data->reg_sns));
  322. } else {
  323. regulator_enable(data->reg_sns);
  324. }
  325. dt_exit:
  326. return errorno;
  327. }
  328. #if defined(CONFIG_SEC_PATEK_PROJECT)
  329. static int ssp_gesture_regulator_onoff(struct ssp_data *data, int onoff)
  330. {
  331. int rc = 0;
  332. struct regulator *regulator_led_3p3;
  333. struct regulator *regulator_vdd_1p8;
  334. pr_info("[SSP] %s - start = %d\n", __func__, onoff);
  335. regulator_vdd_1p8 = regulator_get(NULL, data->ges_vdd);
  336. if (IS_ERR(regulator_vdd_1p8)) {
  337. pr_err("[SSP] %s - vdd_1p8 regulator_get fail\n", __func__);
  338. return -ENODEV;
  339. }
  340. regulator_led_3p3 = regulator_get(NULL, data->ges_led);
  341. if (IS_ERR(regulator_led_3p3)) {
  342. pr_err("[SSP] %s - vdd_3p3 regulator_get fail\n", __func__);
  343. regulator_put(regulator_vdd_1p8);
  344. return -ENODEV;
  345. }
  346. pr_info("[SSP] %s - onoff = %d\n", __func__, onoff);
  347. if (onoff == GES_LDO_ON) {
  348. regulator_set_voltage(regulator_vdd_1p8, 1800000, 1800000);
  349. rc = regulator_enable(regulator_vdd_1p8);
  350. if (rc) {
  351. pr_err("[SSP] %s - enable vdd_1p8 failed, rc=%d\n",
  352. __func__, rc);
  353. goto done;
  354. }
  355. regulator_set_voltage(regulator_led_3p3, 3300000, 3300000);
  356. rc = regulator_enable(regulator_led_3p3);
  357. if (rc) {
  358. pr_err("[SSP] %s - enable led_3p3 failed, rc=%d\n",
  359. __func__, rc);
  360. goto done;
  361. }
  362. }else {
  363. rc = regulator_disable(regulator_vdd_1p8);
  364. if (rc) {
  365. pr_err("[SSP] %s - disable vdd_1p8 failed, rc=%d\n",
  366. __func__, rc);
  367. goto done;
  368. }
  369. rc = regulator_disable(regulator_led_3p3);
  370. if (rc) {
  371. pr_err("[SSP] %s - disable led_3p3 failed, rc=%d\n",
  372. __func__, rc);
  373. goto done;
  374. }
  375. }
  376. data->regulator_is_enable = (u8)onoff;
  377. done:
  378. regulator_put(regulator_led_3p3);
  379. regulator_put(regulator_vdd_1p8);
  380. return rc;
  381. }
  382. #endif
  383. static int ssp_probe(struct spi_device *spi_dev)
  384. {
  385. int iRet = 0;
  386. struct ssp_data *data;
  387. struct ssp_platform_data *pdata;
  388. #if defined(CONFIG_SEC_PATEK_PROJECT)
  389. int err =-1;
  390. #endif
  391. pr_info("[SSP] %s\n", __func__);
  392. if (poweroff_charging == 1 || boot_mode_recovery == 1) {
  393. pr_err("[SSP] probe exit : lpm %d, recovery %d\n",
  394. poweroff_charging, boot_mode_recovery);
  395. return -ENODEV;
  396. }
  397. data = kzalloc(sizeof(*data), GFP_KERNEL);
  398. if (data == NULL) {
  399. pr_err("[SSP]: %s - failed to allocate memory for data\n",
  400. __func__);
  401. iRet = -ENOMEM;
  402. goto exit;
  403. }
  404. if (spi_dev->dev.of_node) {
  405. iRet = ssp_parse_dt(&spi_dev->dev, data);
  406. if (iRet) {
  407. pr_err("[SSP]: %s - Failed to parse DT\n", __func__);
  408. goto err_setup;
  409. }
  410. data->ssp_changes = SSP_MCU_L5; /* K330, MPU L5*/
  411. } else {
  412. pdata = spi_dev->dev.platform_data;
  413. if (pdata == NULL) {
  414. pr_err("[SSP]: %s - platform_data is null\n", __func__);
  415. iRet = -ENOMEM;
  416. goto err_setup;
  417. }
  418. data->wakeup_mcu = pdata->wakeup_mcu;
  419. data->check_mcu_ready = pdata->check_mcu_ready;
  420. data->check_mcu_busy = pdata->check_mcu_busy;
  421. data->set_mcu_reset = pdata->set_mcu_reset;
  422. data->read_chg = pdata->read_chg;
  423. /* AP system_rev */
  424. if (pdata->check_ap_rev)
  425. data->ap_rev = pdata->check_ap_rev();
  426. else
  427. data->ap_rev = 0;
  428. /* For changed devices */
  429. if (pdata->check_changes)
  430. data->ssp_changes = pdata->check_changes();
  431. else
  432. data->ssp_changes = SSP_MCU_L5; /* K330, MPU L5*/
  433. /* Get sensor positions */
  434. if (pdata->get_positions)
  435. pdata->get_positions(&data->accel_position,
  436. &data->mag_position);
  437. else if (spi_dev->dev.of_node == NULL) {
  438. data->accel_position = 0;
  439. data->mag_position = 0;
  440. }
  441. }
  442. #if defined(CONFIG_SEC_PATEK_PROJECT)
  443. err = ssp_gesture_regulator_onoff(data, GES_LDO_ON);
  444. if (err < 0) {
  445. pr_err("[SSP] %s max88922_regulator_on fail err = %d\n",
  446. __func__, err);
  447. //goto err_setup;
  448. }
  449. usleep_range(1000, 1100);
  450. #endif
  451. spi_dev->mode = SPI_MODE_1;
  452. if (spi_setup(spi_dev)) {
  453. pr_err("failed to setup spi for ssp_spi\n");
  454. goto err_setup;
  455. }
  456. data->bProbeIsDone = false;
  457. data->fw_dl_state = FW_DL_STATE_NONE;
  458. data->spi = spi_dev;
  459. spi_set_drvdata(spi_dev, data);
  460. #ifdef CONFIG_DUAL_LCD
  461. magnetic_set_ssp_info(data);
  462. #endif
  463. #ifdef CONFIG_SENSORS_SSP_SHTC1
  464. mutex_init(&data->cp_temp_adc_lock);
  465. mutex_init(&data->bulk_temp_read_lock);
  466. #endif
  467. #ifdef CONFIG_SENSORS_SSP_STM
  468. mutex_init(&data->comm_mutex);
  469. mutex_init(&data->pending_mutex);
  470. #endif
  471. if (((data->wakeup_mcu == NULL)
  472. || (data->check_mcu_ready == NULL)
  473. || (data->check_mcu_busy == NULL)
  474. || (data->set_mcu_reset == NULL)
  475. || (data->read_chg == NULL))
  476. && (spi_dev->dev.of_node == NULL)) {
  477. pr_err("[SSP]: %s - function callback is null\n", __func__);
  478. iRet = -EIO;
  479. goto err_reset_null;
  480. }
  481. pr_info("\n#####################################################\n");
  482. INIT_DELAYED_WORK(&data->work_firmware, work_function_firmware_update);
  483. wake_lock_init(&data->ssp_wake_lock,
  484. WAKE_LOCK_SUSPEND, "ssp_wake_lock");
  485. iRet = initialize_input_dev(data);
  486. if (iRet < 0) {
  487. pr_err("[SSP]: %s - could not create input device\n", __func__);
  488. goto err_input_register_device;
  489. }
  490. iRet = initialize_debug_timer(data);
  491. if (iRet < 0) {
  492. pr_err("[SSP]: %s - could not create workqueue\n", __func__);
  493. goto err_create_workqueue;
  494. }
  495. iRet = initialize_irq(data);
  496. if (iRet < 0) {
  497. pr_err("[SSP]: %s - could not create irq\n", __func__);
  498. goto err_setup_irq;
  499. }
  500. iRet = initialize_sysfs(data);
  501. if (iRet < 0) {
  502. pr_err("[SSP]: %s - could not create sysfs\n", __func__);
  503. goto err_sysfs_create;
  504. }
  505. iRet = initialize_event_symlink(data);
  506. if (iRet < 0) {
  507. pr_err("[SSP]: %s - could not create symlink\n", __func__);
  508. goto err_symlink_create;
  509. }
  510. initialize_variable(data);
  511. #ifdef CONFIG_SENSORS_SSP_SENSORHUB
  512. /* init sensorhub device */
  513. iRet = ssp_sensorhub_initialize(data);
  514. if (iRet < 0) {
  515. pr_err("%s: ssp_sensorhub_initialize err(%d)", __func__, iRet);
  516. ssp_sensorhub_remove(data);
  517. }
  518. #endif
  519. ssp_enable(data, true);
  520. /* check boot loader binary */
  521. data->fw_dl_state = check_fwbl(data);
  522. if (data->fw_dl_state == FW_DL_STATE_NONE) {
  523. iRet = initialize_mcu(data);
  524. if (iRet == ERROR) {
  525. toggle_mcu_reset(data);
  526. } else if (iRet < ERROR) {
  527. pr_err("[SSP]: %s - initialize_mcu failed\n", __func__);
  528. goto err_read_reg;
  529. }
  530. }
  531. #ifdef CONFIG_HAS_EARLYSUSPEND
  532. data->early_suspend.suspend = ssp_early_suspend;
  533. data->early_suspend.resume = ssp_late_resume;
  534. register_early_suspend(&data->early_suspend);
  535. #endif
  536. #ifdef CONFIG_DUAL_LCD
  537. /* if read gpio , 0: close, 1:open so flip_status 0:open, 1:close*/
  538. flip_status = !(gpio_get_value(HALL_SENSOR_INT_GPIO));
  539. pr_info("[SSP] %s : Folder is %sed now.\n", __func__,flip_status ? "clos":"open");
  540. #endif
  541. pr_info("[SSP]: %s - probe success!\n", __func__);
  542. enable_debug_timer(data);
  543. iRet = 0;
  544. if (data->fw_dl_state == FW_DL_STATE_NEED_TO_SCHEDULE) {
  545. pr_info("[SSP]: Firmware update is scheduled\n");
  546. schedule_delayed_work(&data->work_firmware,
  547. msecs_to_jiffies(1000));
  548. data->fw_dl_state = FW_DL_STATE_SCHEDULED;
  549. } else if (data->fw_dl_state == FW_DL_STATE_FAIL)
  550. data->bSspShutdown = true;
  551. data->bProbeIsDone = true;
  552. goto exit;
  553. err_read_reg:
  554. err_symlink_create:
  555. remove_sysfs(data);
  556. err_sysfs_create:
  557. free_irq(data->iIrq, data);
  558. gpio_free(data->mcu_int1);
  559. err_setup_irq:
  560. destroy_workqueue(data->debug_wq);
  561. err_create_workqueue:
  562. remove_input_dev(data);
  563. err_input_register_device:
  564. wake_lock_destroy(&data->ssp_wake_lock);
  565. err_reset_null:
  566. #ifdef CONFIG_SENSORS_SSP_SHTC1
  567. mutex_destroy(&data->cp_temp_adc_lock);
  568. mutex_destroy(&data->bulk_temp_read_lock);
  569. #endif
  570. #ifdef CONFIG_SENSORS_SSP_STM
  571. mutex_destroy(&data->comm_mutex);
  572. mutex_destroy(&data->pending_mutex);
  573. #endif
  574. err_setup:
  575. kfree(data);
  576. pr_err("[SSP]: %s - probe failed!\n", __func__);
  577. exit:
  578. pr_info("#####################################################\n\n");
  579. return iRet;
  580. }
  581. static void ssp_shutdown(struct spi_device *spi_dev)
  582. {
  583. struct ssp_data *data = spi_get_drvdata(spi_dev);
  584. func_dbg();
  585. if (data->bProbeIsDone == false)
  586. goto exit;
  587. if (data->fw_dl_state >= FW_DL_STATE_SCHEDULED &&
  588. data->fw_dl_state < FW_DL_STATE_DONE) {
  589. pr_err("%s, cancel_delayed_work_sync state = %d\n",
  590. __func__, data->fw_dl_state);
  591. cancel_delayed_work_sync(&data->work_firmware);
  592. }
  593. disable_debug_timer(data);
  594. if (SUCCESS != ssp_send_cmd(data, MSG2SSP_AP_STATUS_SHUTDOWN, 0))
  595. pr_err("[SSP]: %s MSG2SSP_AP_STATUS_SHUTDOWN failed\n",
  596. __func__);
  597. ssp_enable(data, false);
  598. clean_pending_list(data);
  599. #ifdef CONFIG_HAS_EARLYSUSPEND
  600. unregister_early_suspend(&data->early_suspend);
  601. #endif
  602. free_irq(data->iIrq, data);
  603. gpio_free(data->mcu_int1);
  604. remove_event_symlink(data);
  605. remove_sysfs(data);
  606. remove_input_dev(data);
  607. #ifdef CONFIG_SENSORS_SSP_SENSORHUB
  608. ssp_sensorhub_remove(data);
  609. #endif
  610. cancel_delayed_work_sync(&data->work_refresh);
  611. destroy_workqueue(data->debug_wq);
  612. wake_lock_destroy(&data->ssp_wake_lock);
  613. #ifdef CONFIG_SENSORS_SSP_SHTC1
  614. mutex_destroy(&data->cp_temp_adc_lock);
  615. mutex_destroy(&data->bulk_temp_read_lock);
  616. #endif
  617. #ifdef CONFIG_SENSORS_SSP_STM
  618. mutex_destroy(&data->comm_mutex);
  619. mutex_destroy(&data->pending_mutex);
  620. #endif
  621. toggle_mcu_reset(data);
  622. /* gpio_set_value_cansleep(data->rst, 0); */
  623. pr_info("[SSP]: %s done\n", __func__);
  624. exit:
  625. kfree(data);
  626. }
  627. #ifdef CONFIG_HAS_EARLYSUSPEND
  628. static void ssp_early_suspend(struct early_suspend *handler)
  629. {
  630. struct ssp_data *data;
  631. data = container_of(handler, struct ssp_data, early_suspend);
  632. func_dbg();
  633. disable_debug_timer(data);
  634. #ifdef CONFIG_SENSORS_SSP_SENSORHUB
  635. /* give notice to user that AP goes to sleep */
  636. ssp_sensorhub_report_notice(data, MSG2SSP_AP_STATUS_SLEEP);
  637. ssp_sleep_mode(data);
  638. data->uLastAPState = MSG2SSP_AP_STATUS_SLEEP;
  639. #else
  640. if (atomic_read(&data->aSensorEnable) > 0)
  641. ssp_sleep_mode(data);
  642. #endif
  643. }
  644. static void ssp_late_resume(struct early_suspend *handler)
  645. {
  646. struct ssp_data *data;
  647. data = container_of(handler, struct ssp_data, early_suspend);
  648. func_dbg();
  649. enable_debug_timer(data);
  650. #ifdef CONFIG_SENSORS_SSP_SENSORHUB
  651. /* give notice to user that AP goes to sleep */
  652. ssp_sensorhub_report_notice(data, MSG2SSP_AP_STATUS_WAKEUP);
  653. ssp_resume_mode(data);
  654. data->uLastAPState = MSG2SSP_AP_STATUS_WAKEUP;
  655. #else
  656. if (atomic_read(&data->aSensorEnable) > 0)
  657. ssp_resume_mode(data);
  658. #endif
  659. }
  660. #else /* CONFIG_HAS_EARLYSUSPEND */
  661. static int ssp_suspend(struct device *dev)
  662. {
  663. struct spi_device *spi_dev = to_spi_device(dev);
  664. struct ssp_data *data = spi_get_drvdata(spi_dev);
  665. func_dbg();
  666. data->uLastResumeState = MSG2SSP_AP_STATUS_SUSPEND;
  667. disable_debug_timer(data);
  668. if (SUCCESS != ssp_send_cmd(data, MSG2SSP_AP_STATUS_SUSPEND, 0))
  669. pr_err("[SSP]: %s MSG2SSP_AP_STATUS_SUSPEND failed\n",
  670. __func__);
  671. data->bTimeSyncing = false;
  672. disable_irq(data->iIrq);
  673. return 0;
  674. }
  675. static int ssp_resume(struct device *dev)
  676. {
  677. struct spi_device *spi_dev = to_spi_device(dev);
  678. struct ssp_data *data = spi_get_drvdata(spi_dev);
  679. enable_irq(data->iIrq);
  680. func_dbg();
  681. enable_debug_timer(data);
  682. if (SUCCESS != ssp_send_cmd(data, MSG2SSP_AP_STATUS_RESUME, 0))
  683. pr_err("[SSP]: %s MSG2SSP_AP_STATUS_RESUME failed\n",
  684. __func__);
  685. data->uLastResumeState = MSG2SSP_AP_STATUS_RESUME;
  686. return 0;
  687. }
  688. static const struct dev_pm_ops ssp_pm_ops = {
  689. .suspend = ssp_suspend,
  690. .resume = ssp_resume
  691. };
  692. #endif /* CONFIG_HAS_EARLYSUSPEND */
  693. static const struct spi_device_id ssp_id[] = {
  694. {"ssp", 0},
  695. {}
  696. };
  697. MODULE_DEVICE_TABLE(spi, ssp_id);
  698. #ifdef CONFIG_OF
  699. static struct of_device_id ssp_match_table[] = {
  700. { .compatible = "ssp,STM32F",},
  701. {},
  702. };
  703. #else
  704. #define mpu6500_match_table NULL
  705. #endif
  706. static struct spi_driver ssp_driver = {
  707. .probe = ssp_probe,
  708. .shutdown = ssp_shutdown,
  709. .id_table = ssp_id,
  710. .driver = {
  711. #ifndef CONFIG_HAS_EARLYSUSPEND
  712. .pm = &ssp_pm_ops,
  713. #endif
  714. .owner = THIS_MODULE,
  715. .name = "ssp",
  716. .of_match_table = ssp_match_table
  717. },
  718. };
  719. module_spi_driver(ssp_driver);
  720. MODULE_DESCRIPTION("ssp driver");
  721. MODULE_AUTHOR("Samsung Electronics");
  722. MODULE_LICENSE("GPL");