kernel:aw8695 rtp vibrate feature
authorxuwei9 <xuwei9@lenovo.com>
Thu, 31 Jan 2019 05:56:55 +0000 (13:56 +0800)
committerxiest1 <xiest1@lenovo.com>
Tue, 5 Nov 2019 09:30:42 +0000 (17:30 +0800)
aw8695 rtp vibrate feature
wave id

Change-Id: Ibcba4333774d32dee00be56c336e072b829862f8
Signed-off-by: xuwei9 <xuwei9@mt.com>
Reviewed-on: https://gerrit.mot.com/1303448
SLTApproved: Slta Waiver
SME-Granted: SME Approvals Granted
Tested-by: Jira Key
Reviewed-by: Xiangpo Zhao <zhaoxp3@motorola.com>
Submit-Approved: Jira Key

drivers/misc/aw8695_haptic/aw8695.c

index a1035eb73c37e1e592f01b637e4ba044a1ba73f4..aaf81b68a50d495fab89e6e32733edf5fcd160d1 100755 (executable)
@@ -1773,12 +1773,23 @@ static int aw8695_haptic_init(struct aw8695 *aw8695)
 #ifdef MOTO_VIBRATOR_SUPPORT
 static void aw8695_rtp_play(struct aw8695 *aw8695, int value)
 {
+    int val = value + AW8695_SEQ_NO_RTP_BASE - 2;
+    int index;
+
     aw8695_haptic_stop(aw8695);
     aw8695_haptic_set_rtp_aei(aw8695, false);
     aw8695_interrupt_clear(aw8695);
-    if(value < (sizeof(aw8695_rtp_name)/AW8695_RTP_NAME_MAX)) {
-        aw8695->rtp_file_num = value;
-        if(value) {
+
+    for(index = 0; index < AW8695_RTP_NAME_MAX; ++index){
+        if(val == aw8695_rtp_wave_id[index].system_index) {
+            val = aw8695_rtp_wave_id[index].driver_index;
+            break;
+        }
+    }
+
+    if(val < (sizeof(aw8695_rtp_name)/AW8695_RTP_NAME_MAX)) {
+        aw8695->rtp_file_num = val;
+        if(val) {
             schedule_work(&aw8695->rtp_work);
         }
     } else {
@@ -1794,7 +1805,8 @@ static void aw8695_vibrate(struct aw8695 *aw8695, int value)
 
     aw8695_haptic_stop(aw8695);
     seq = aw8695->seq[0];
-    pr_debug("%s: value=%d, seq=%d\n", __FUNCTION__, value, seq);
+
+    pr_info("%s: value=%d, seq=%d\n", __FUNCTION__, value, seq);
 
     if (value > 0 || seq > 2) {
         if (seq >= AW8695_SEQ_NO_RTP_BASE) {
@@ -2257,8 +2269,8 @@ static ssize_t aw8695_seq_store(struct device *dev,
     rc = kstrtouint(buf, 0, &val);
     if (rc < 0)
         return rc;
-    val = ((val >> 24) -2) ;
-    pr_debug("%s: value=%x\n", __FUNCTION__, val);
+
+    pr_info("%s: value=%x\n", __FUNCTION__, val);
     mutex_lock(&aw8695->lock);
     for(i=0; i<4; i++) {
         aw8695->seq[i] = (val>>((AW8695_WAV_SEQ_SIZE-i-1)*8))&0xFF;