Mercurial > mplayer.hg
view TOOLS/blocking.c @ 8575:1d15ca298dda
Fix DVD authentication on Solaris 9.
Solaris 9 does not allow USCSICMD ioctls for non-root users on vold devices
any more; they are failing with an EPERM "permission denied" error. Now, only
root is allowed to run USCSICMD ioctls on vold devices.
Fortunatelly there's a new subroutine exported from libsmedia.so
(smedia_uscsi_cmd) which allows non-root users to perform user mode SCSI
commands on a vold device. (This works with a help of a daemon running as
user root, /usr/lib/smedia/rpc.smserverd)
This change detects the presence of function "smedia_uscsi_cmd" in library
libsmedia.so at runtime, and uses this function if it's found (i.e. on
solaris 9 smedia_uscsi_cmd() is used to execture user mode scsi commands).
On solaris 8 or older, "smedia_uscsi_cmd" is not available and the code
falls back to the old ioctl(.. USCSICMD ..) method.
author | jkeil |
---|---|
date | Fri, 27 Dec 2002 16:29:11 +0000 |
parents | b9ad3b70fc61 |
children |
line wrap: on
line source
#include <stdio.h> #include <stdlib.h> #include <sys/time.h> #include <sys/types.h> #include <unistd.h> #include <sys/stat.h> #include <fcntl.h> #define BUFFSIZE (32*65536) unsigned char *buffer[1]; int main(int argc,char* argv[]){ fd_set rfds; struct timeval tv; int retval; int in_fd=0; // stdin buffer[0]=malloc(BUFFSIZE); if(argc>1) in_fd=open(argv[1],O_RDONLY|O_NONBLOCK); while(1){ FD_ZERO(&rfds); FD_SET(in_fd, &rfds); tv.tv_sec = 1; tv.tv_usec = 0; retval = select(in_fd+1, &rfds, NULL, NULL, &tv); if (retval){ if(FD_ISSET(in_fd, &rfds)){ // we can read input. int len; fprintf(stderr,"r");fflush(stderr); len=read(in_fd,buffer[0],BUFFSIZE); fprintf(stderr,"(%d)",len);fflush(stderr); } } else { fprintf(stderr,".");fflush(stderr); } fprintf(stderr,"\n");fflush(stderr); } return 0; }