1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun * rotary_test.c -- rotary test application
3*4882a593Smuzhiyun *
4*4882a593Smuzhiyun * Copyright (c) 2017 Rockchip Electronics Co. Ltd.
5*4882a593Smuzhiyun * Author: Bin Yang <yangbin@rock-chips.com>
6*4882a593Smuzhiyun * Author: Panzhenzhuan Wang <randy.wang@rock-chips.com>
7*4882a593Smuzhiyun *
8*4882a593Smuzhiyun * Licensed under the Apache License, Version 2.0 (the "License");
9*4882a593Smuzhiyun * you may not use this file except in compliance with the License.
10*4882a593Smuzhiyun * You may obtain a copy of the License at
11*4882a593Smuzhiyun *
12*4882a593Smuzhiyun * http://www.apache.org/licenses/LICENSE-2.0
13*4882a593Smuzhiyun *
14*4882a593Smuzhiyun * Unless required by applicable law or agreed to in writing, software
15*4882a593Smuzhiyun * distributed under the License is distributed on an "AS IS" BASIS,
16*4882a593Smuzhiyun * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17*4882a593Smuzhiyun * See the License for the specific language governing permissions and
18*4882a593Smuzhiyun * limitations under the License.
19*4882a593Smuzhiyun */
20*4882a593Smuzhiyun #include <stdio.h>
21*4882a593Smuzhiyun #include <stdlib.h>
22*4882a593Smuzhiyun #include <string.h>
23*4882a593Smuzhiyun #include <errno.h>
24*4882a593Smuzhiyun #include <fcntl.h>
25*4882a593Smuzhiyun #include <linux/input.h>
26*4882a593Smuzhiyun #include <signal.h>
27*4882a593Smuzhiyun #include <unistd.h>
28*4882a593Smuzhiyun
29*4882a593Smuzhiyun #define LOG_TAG "rotary_test"
30*4882a593Smuzhiyun #include "common.h"
31*4882a593Smuzhiyun
32*4882a593Smuzhiyun #define ROTARY_INPUT_EVENT "/dev/input/event1"
33*4882a593Smuzhiyun
34*4882a593Smuzhiyun #define ROTARY_TIMEOUT_ROTATE 60 //60s��ʱ
35*4882a593Smuzhiyun
36*4882a593Smuzhiyun static char result[COMMAND_VALUESIZE] = RESULT_FAIL;
37*4882a593Smuzhiyun
rotary_wait_event(int maxfd,fd_set * readfds,int time)38*4882a593Smuzhiyun static int rotary_wait_event(int maxfd, fd_set *readfds, int time)
39*4882a593Smuzhiyun {
40*4882a593Smuzhiyun int ret;
41*4882a593Smuzhiyun struct timeval timeout;
42*4882a593Smuzhiyun
43*4882a593Smuzhiyun FD_ZERO(readfds);
44*4882a593Smuzhiyun FD_SET(maxfd, readfds);
45*4882a593Smuzhiyun timeout.tv_sec = time;
46*4882a593Smuzhiyun timeout.tv_usec = 0;
47*4882a593Smuzhiyun ret = select(maxfd + 1, readfds, NULL, NULL, &timeout);
48*4882a593Smuzhiyun switch (ret) {
49*4882a593Smuzhiyun case -1:
50*4882a593Smuzhiyun return -1;
51*4882a593Smuzhiyun case 0:
52*4882a593Smuzhiyun log_err("select timeout(%ds)\n", time);
53*4882a593Smuzhiyun return 1;
54*4882a593Smuzhiyun default:
55*4882a593Smuzhiyun if (FD_ISSET(maxfd, readfds)) {
56*4882a593Smuzhiyun FD_CLR (maxfd, readfds);
57*4882a593Smuzhiyun return 0;
58*4882a593Smuzhiyun }
59*4882a593Smuzhiyun break;
60*4882a593Smuzhiyun }
61*4882a593Smuzhiyun
62*4882a593Smuzhiyun return -1;
63*4882a593Smuzhiyun }
64*4882a593Smuzhiyun
rotary_event_read(int fd,struct input_event * buf)65*4882a593Smuzhiyun static int rotary_event_read(int fd, struct input_event *buf)
66*4882a593Smuzhiyun {
67*4882a593Smuzhiyun int read_len = 0;
68*4882a593Smuzhiyun
69*4882a593Smuzhiyun read_len = read(fd, buf, sizeof(*buf));
70*4882a593Smuzhiyun if (read_len < 0) {
71*4882a593Smuzhiyun if ((errno != EINTR) && (errno != EAGAIN))
72*4882a593Smuzhiyun return 0;
73*4882a593Smuzhiyun return -1;
74*4882a593Smuzhiyun }
75*4882a593Smuzhiyun
76*4882a593Smuzhiyun if (buf->type)
77*4882a593Smuzhiyun return 1;
78*4882a593Smuzhiyun
79*4882a593Smuzhiyun return 0;
80*4882a593Smuzhiyun }
81*4882a593Smuzhiyun
82*4882a593Smuzhiyun //* �źŴ��������ڽ�������ǰ��Ϊrotary���Է���һ�������
rotary_result_send(int sign_no)83*4882a593Smuzhiyun static int rotary_result_send(int sign_no)
84*4882a593Smuzhiyun {
85*4882a593Smuzhiyun int err_code =0;
86*4882a593Smuzhiyun printf("====================function : %s start =================\n",__func__);
87*4882a593Smuzhiyun if(!memcmp(result,RESULT_FAIL,strlen(RESULT_FAIL))){
88*4882a593Smuzhiyun err_code = ROTARY_QUERY_FAIL;
89*4882a593Smuzhiyun }
90*4882a593Smuzhiyun send_msg_to_server("rotary_test", result, err_code);
91*4882a593Smuzhiyun
92*4882a593Smuzhiyun printf("====================function : %s finished =================\n",__func__);
93*4882a593Smuzhiyun exit(0);
94*4882a593Smuzhiyun }
95*4882a593Smuzhiyun
main(int argc,char ** argv)96*4882a593Smuzhiyun int main(int argc, char **argv)
97*4882a593Smuzhiyun {
98*4882a593Smuzhiyun int fd;
99*4882a593Smuzhiyun int ret = 0;
100*4882a593Smuzhiyun int err_code = 0;
101*4882a593Smuzhiyun int time = ROTARY_TIMEOUT_ROTATE;
102*4882a593Smuzhiyun fd_set rdfds;
103*4882a593Smuzhiyun struct input_event rotary_event;
104*4882a593Smuzhiyun unsigned short clockwise=0,anticlockwise=0; //��־��ת����
105*4882a593Smuzhiyun char buf[COMMAND_VALUESIZE] = {0};
106*4882a593Smuzhiyun //char result[COMMAND_VALUESIZE] = RESULT_VERIFY;
107*4882a593Smuzhiyun
108*4882a593Smuzhiyun log_info("rotary test process start...\n");
109*4882a593Smuzhiyun
110*4882a593Smuzhiyun //* ע���źŴ�����
111*4882a593Smuzhiyun signal(SIGTERM,(__sighandler_t)rotary_result_send);
112*4882a593Smuzhiyun
113*4882a593Smuzhiyun fd = open(ROTARY_INPUT_EVENT, O_RDONLY | O_NOCTTY);
114*4882a593Smuzhiyun if (fd < 0) {
115*4882a593Smuzhiyun log_err("open fail:%s\n", strerror(errno));
116*4882a593Smuzhiyun err_code = ROTARY_OPEN_FAIL;
117*4882a593Smuzhiyun goto EXIT;
118*4882a593Smuzhiyun }
119*4882a593Smuzhiyun
120*4882a593Smuzhiyun while (1&&!(clockwise&&anticlockwise)) {
121*4882a593Smuzhiyun if (rotary_wait_event(fd, &rdfds, time) == 0) {
122*4882a593Smuzhiyun ret = rotary_event_read(fd, &rotary_event);
123*4882a593Smuzhiyun if (ret > 0) {
124*4882a593Smuzhiyun if (1==rotary_event.value) {
125*4882a593Smuzhiyun log_info("rotary(%d) is clockwise\n", rotary_event.code);
126*4882a593Smuzhiyun time = ROTARY_TIMEOUT_ROTATE;
127*4882a593Smuzhiyun clockwise = 0x1;
128*4882a593Smuzhiyun } else if(-1 == rotary_event.value){
129*4882a593Smuzhiyun log_info("rotary(%d) is anticlockwise\n", rotary_event.code);
130*4882a593Smuzhiyun time = ROTARY_TIMEOUT_ROTATE;
131*4882a593Smuzhiyun anticlockwise = 0x1;
132*4882a593Smuzhiyun }
133*4882a593Smuzhiyun }
134*4882a593Smuzhiyun } else {
135*4882a593Smuzhiyun log_err("wait rotary event fail, errno=%d\n", errno);
136*4882a593Smuzhiyun err_code = ROTARY_EVENT_TIMEOUT;
137*4882a593Smuzhiyun goto EXIT;
138*4882a593Smuzhiyun }
139*4882a593Smuzhiyun }
140*4882a593Smuzhiyun snprintf(buf, sizeof(buf), "rotary_code:%d", rotary_event.code);
141*4882a593Smuzhiyun
142*4882a593Smuzhiyun EXIT:
143*4882a593Smuzhiyun if (!err_code)
144*4882a593Smuzhiyun strcpy(result, RESULT_VERIFY);
145*4882a593Smuzhiyun send_msg_to_server(buf, result, err_code);
146*4882a593Smuzhiyun
147*4882a593Smuzhiyun return err_code;
148*4882a593Smuzhiyun }
149