annotate codecctrl.c @ 20:e1147bb68942

DOCS update (DGA)
author gabucino
date Tue, 27 Feb 2001 12:05:51 +0000
parents 3b5f5d1c5041
children 846535ace7a2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
2 //#define DEBUG_SIGNALS
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
3 #define DEBUG_SIGNALS_SLEEP ;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
4 //#define DEBUG_SIGNALS_SLEEP sleep(2);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
5
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
6 #ifdef DEBUG_SIGNALS
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
7 #define DEBUG_SIG if(1)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
8 #else
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
9 #define DEBUG_SIG if(0)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
10 #endif
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
11
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
12 //======= Interprocess Comminication (IPC) between player & codec =========
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
13
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
14 static int child_pid=0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
15 static int codec_pid=0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
16
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
17 // player:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
18 static int data_fifo=-1;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
19 static int control_fifo=-1;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
20 // codec:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
21 static int data_fifo2=-1;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
22 static int control_fifo2=-1;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
23 // keyboard:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
24 static int keyb_fifo_put=-1;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
25 static int keyb_fifo_get=-1;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
26
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
27
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
28 // SIGTERM handler of codec controller (2nd process):
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
29 static void codec_ctrl_sighandler(int x){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
30 DEBUG_SIG printf("\nCTRL: received signal %d, terminating child first:\n",x);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
31 // first terminate the codec:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
32 //kill(child_pid,SIGTERM);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
33 kill(child_pid,x);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
34 usleep(50000); // 50ms must be enough
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
35 DEBUG_SIG printf("CTRL: Sending KILL signal to child:\n");
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
36 kill(child_pid,SIGKILL); // worst case
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
37 usleep(10000);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
38 // and exit
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
39 if(x!=SIGHUP){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
40 DEBUG_SIG printf("CTRL: Exiting...\n");
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
41 exit(0);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
42 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
43 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
44
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
45 static vo_functions_t *codec_video_out_ptr=NULL;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
46
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
47 // SIGTERM handler of the codec (3nd process):
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
48 static void codec_sighandler(int x){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
49 DEBUG_SIG printf("\nCHILD: received signal %d, exiting...\n",x);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
50 if(x==SIGTERM){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
51 //mpeg2_close(codec_video_out_ptr);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
52 codec_video_out_ptr->uninit(); // closing video_out
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
53 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
54 exit(0);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
55 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
56
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
57
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
58 static void make_pipe(int* pr,int* pw){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
59 int temp[2];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
60 if(pipe(temp)!=0) printf("Cannot make PIPE!\n");
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
61 *pr=temp[0];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
62 *pw=temp[1];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
63 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
64
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
65 static inline int my_write(int fd,unsigned char* mem,int len){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
66 int total=0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
67 int len2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
68 while(len>0){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
69 len2=write(fd,mem+total,len); if(len2<=0) break;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
70 total+=len2;len-=len2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
71 // printf("%d bytes received, %d left\n",len2,len);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
72 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
73 return total;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
74 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
75
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
76 static inline int my_read(int fd,unsigned char* mem,int len){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
77 int total=0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
78 int len2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
79 while(len>0){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
80 len2=read(fd,mem+total,len); if(len2<=0) break;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
81 total+=len2;len-=len2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
82 // printf("%d bytes received, %d left\n",len2,len);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
83 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
84 return total;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
85 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
86
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
87
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
88 void send_cmd(int fd,int cmd){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
89 int fifo_cmd=cmd;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
90 write(fd,&fifo_cmd,4);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
91 // fflush(control_fifo);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
92 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
93
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
94 void mpeg_codec_controller(vo_functions_t *video_out){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
95 //================== CODEC Controller: ==========================
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
96 signal(SIGTERM,codec_ctrl_sighandler); // set our SIGTERM handler
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
97 signal(SIGHUP,codec_ctrl_sighandler); // set our SIGHUP handler
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
98 printf("starting video codec...\n");
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
99 while(1){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
100 int status;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
101 if((child_pid=fork())==0){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
102 // child:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
103 unsigned int t=0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
104 codec_video_out_ptr=video_out;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
105 #if 0
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
106 signal(SIGTERM,codec_sighandler); // set our SIGTERM handler
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
107 signal(SIGHUP,codec_sighandler); // set our SIGHUP handler
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
108 #else
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
109 // terminate requests:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
110 signal(SIGTERM,codec_sighandler); // kill
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
111 signal(SIGHUP,codec_sighandler); // kill -HUP / xterm closed
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
112 signal(SIGINT,codec_sighandler); // Interrupt from keyboard
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
113 signal(SIGQUIT,codec_sighandler); // Quit from keyboard
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
114 // fatal errors:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
115 signal(SIGBUS,codec_sighandler); // bus error
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
116 signal(SIGSEGV,codec_sighandler); // segfault
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
117 signal(SIGILL,codec_sighandler); // illegal instruction
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
118 signal(SIGFPE,codec_sighandler); // floating point exc.
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
119 signal(SIGABRT,codec_sighandler); // abort()
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
120 #endif
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
121
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
122 send_cmd(control_fifo2,0x22222222); // Send WE_ARE_READY command
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
123 send_cmd(control_fifo2,getpid()); // Send out PID
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
124 while(1){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
125 unsigned int syncword=0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
126 read(data_fifo2,&syncword,4);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
127 if(syncword==0x22222222) break;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
128 printf("codec: drop bad frame (%X)\n",syncword);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
129 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
130 //printf("codec: connection synced\n");
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
131
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
132 while(1){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
133 int num_frames;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
134 int len=0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
135 int len2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
136 send_cmd(control_fifo2,0x3030303);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
137 len2=my_read(data_fifo2,(unsigned char*) &len,4);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
138 if(len2!=4){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
139 printf("FATAL: cannot read packet len from data fifo (ret=%d, errno=%d)\n",len2,errno);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
140 break;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
141 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
142 if(len==0){ printf("mpeg2dec: EOF, exiting...\n");break; }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
143 // printf("mpeg2dec: frame (%d bytes) read\n",len);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
144 t-=GetTimer();
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
145 mpeg2_decode_data(video_out, videobuffer, videobuffer+len);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
146 t+=GetTimer();
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
147 send_cmd(control_fifo2,0); // FRAME_COMPLETED command
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
148 send_cmd(control_fifo2,picture->frame_rate); // fps
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
149 send_cmd(control_fifo2,100+picture->repeat_count);picture->repeat_count=0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
150 send_cmd(control_fifo2,t);t=0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
151 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
152 video_out->uninit();
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
153 exit(0); // leave process
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
154 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
155 wait(&status); // Waiting for the child!
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
156 // printf("restarting video codec...\n");
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
157 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
158 exit(0);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
159 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
160
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
161 void mplayer_put_key(int code){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
162 fd_set rfds;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
163 struct timeval tv;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
164
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
165 /* Watch stdin (fd 0) to see when it has input. */
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
166 FD_ZERO(&rfds);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
167 FD_SET(keyb_fifo_put, &rfds);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
168 tv.tv_sec = 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
169 tv.tv_usec = 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
170
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
171 //retval = select(keyb_fifo_put+1, &rfds, NULL, NULL, &tv);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
172 if(select(keyb_fifo_put+1, NULL, &rfds, NULL, &tv)){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
173 write(keyb_fifo_put,&code,4);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
174 // printf("*** key event %d sent ***\n",code);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
175 } else {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
176 // printf("*** key event dropped (FIFO is full) ***\n");
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
177 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
178 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
179
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
180 int mplayer_get_key(){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
181 fd_set rfds;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
182 struct timeval tv;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
183 int code=-1;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
184
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
185 /* Watch stdin (fd 0) to see when it has input. */
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
186 FD_ZERO(&rfds);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
187 FD_SET(keyb_fifo_get, &rfds);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
188 tv.tv_sec = 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
189 tv.tv_usec = 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
190
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
191 //retval = select(keyb_fifo_put+1, &rfds, NULL, NULL, &tv);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
192 if(select(keyb_fifo_put+1, &rfds, NULL, NULL, &tv)){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
193 read(keyb_fifo_get,&code,4);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
194 // printf("*** key event %d read ***\n",code);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
195 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
196 return code;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
197 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
198