X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/9458c6fcf07885c97e8b627b035c848267ee2d0c..acab01604673e3fb0d13e47f9ffb5c32e8d9dd07:/lib/driver/avswitch.cpp diff --git a/lib/driver/avswitch.cpp b/lib/driver/avswitch.cpp index 31db25a4..80c7755b 100644 --- a/lib/driver/avswitch.cpp +++ b/lib/driver/avswitch.cpp @@ -15,14 +15,10 @@ eAVSwitch::eAVSwitch() { ASSERT(!instance); instance = this; - - avsfd = open("/dev/dbox/avs0", O_RDWR); } eAVSwitch::~eAVSwitch() { - if(avsfd > 0) - close(avsfd); } eAVSwitch *eAVSwitch::getInstance() @@ -32,9 +28,84 @@ eAVSwitch *eAVSwitch::getInstance() void eAVSwitch::setColorFormat(int format) { - printf("eAVSwitch::setColorFormat(%d)\n",format); - /*there are no ioctl for controling this in avs - scart api needed - no, not the gillem one */ + /* + 0-CVBS + 1-RGB + 2-S-Video + */ + char *cvbs="cvbs"; + char *rgb="rgb"; + char *svideo="svideo"; + int fd; + + if((fd = open("/proc/stb/avs/0/colorformat", O_WRONLY)) < 0) { + printf("cannot open /proc/stb/avs/0/colorformat\n"); + return; + } + switch(format) { + case 0: + write(fd, cvbs, strlen(cvbs)); + break; + case 1: + write(fd, rgb, strlen(rgb)); + break; + case 2: + write(fd, svideo, strlen(svideo)); + break; + } + close(fd); +} + +void eAVSwitch::setAspectRatio(int ratio) +{ + /* + 0-4:3 Letterbox + 1-4:3 PanScan + 2-16:9 + 3-16:9 forced + */ + + char *aspect[] = {"4:3", "4:3", "any", "16:9"}; + char *policy[] = {"letterbox", "panscan", "bestfit", "panscan"}; + + int fd; + if((fd = open("/proc/stb/video/aspect", O_WRONLY)) < 0) { + printf("cannot open /proc/stb/video/aspect\n"); + return; + } + write(fd, aspect[ratio], strlen(aspect[ratio])); + close(fd); + + if((fd = open("/proc/stb/video/policy", O_WRONLY)) < 0) { + printf("cannot open /proc/stb/video/policy\n"); + return; + } + write(fd, policy[ratio], strlen(policy[ratio])); + close(fd); + +} + +void eAVSwitch::setVideomode(int mode) +{ + char *pal="pal"; + char *ntsc="ntsc"; + int fd; + + return; + //FIXME: bug in driver (cannot set PAL) + if((fd = open("/proc/stb/video/videomode", O_WRONLY)) < 0) { + printf("cannot open /proc/stb/video/videomode\n"); + return; + } + switch(mode) { + case 0: + write(fd, pal, strlen(pal)); + break; + case 1: + write(fd, ntsc, strlen(ntsc)); + break; + } + close(fd); } //FIXME: correct "run/startlevel"