diff options
| author | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2006-02-08 21:24:22 +0000 |
|---|---|---|
| committer | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2006-02-08 21:24:22 +0000 |
| commit | f50ea7e42b05996b75eba9ed4376c539c5fc00ae (patch) | |
| tree | 909ebea5b55c05ee8ffd1503ad128dc3d4ac1602 /lib/driver/avswitch.cpp | |
| parent | b27a6052bb7ca67821f0d6c23b6549ffe70e9dad (diff) | |
| download | enigma2-f50ea7e42b05996b75eba9ed4376c539c5fc00ae.tar.gz enigma2-f50ea7e42b05996b75eba9ed4376c539c5fc00ae.zip | |
dont set /proc/stb values directly from python..
use eavswitch as api abstraction layer
enable pal/ntsc switching
Diffstat (limited to 'lib/driver/avswitch.cpp')
| -rw-r--r-- | lib/driver/avswitch.cpp | 31 |
1 files changed, 24 insertions, 7 deletions
diff --git a/lib/driver/avswitch.cpp b/lib/driver/avswitch.cpp index 12a8f7d9..35df9388 100644 --- a/lib/driver/avswitch.cpp +++ b/lib/driver/avswitch.cpp @@ -54,7 +54,6 @@ void eAVSwitch::setFastBlank(int val) int fd; char *fb[] = {"low", "high", "vcr"}; - if((fd = open("/proc/stb/avs/0/fb", O_WRONLY)) < 0) { printf("cannot open /proc/stb/avs/0/fb\n"); return; @@ -115,6 +114,7 @@ void eAVSwitch::setAspectRatio(int ratio) printf("cannot open /proc/stb/video/aspect\n"); return; } +// eDebug("set aspect to %s", aspect[ratio]); write(fd, aspect[ratio], strlen(aspect[ratio])); close(fd); @@ -122,6 +122,7 @@ void eAVSwitch::setAspectRatio(int ratio) printf("cannot open /proc/stb/video/policy\n"); return; } +// eDebug("set ratio to %s", policy[ratio]); write(fd, policy[ratio], strlen(policy[ratio])); close(fd); @@ -132,9 +133,7 @@ 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; @@ -146,7 +145,24 @@ void eAVSwitch::setVideomode(int mode) case 1: write(fd, ntsc, strlen(ntsc)); break; - } + } + close(fd); +} + +void eAVSwitch::setWSS(int val) // 0 = auto, 1 = auto(4:3_off) +{ + int fd; + if((fd = open("/proc/stb/denc/0/wss", O_WRONLY)) < 0) { + printf("cannot open /proc/stb/denc/0/wss\n"); + return; + } + char *wss[] = { + "off", "auto", "auto(4:3_off)", "4:3_full_format", "16:9_full_format", + "14:9_letterbox_center", "14:9_letterbox_top", "16:9_letterbox_center", + "16:9_letterbox_top", ">16:9_letterbox_center", "14:9_full_format" + }; + write(fd, wss[val], strlen(wss[val])); +// eDebug("set wss to %s", wss[val]); close(fd); } @@ -157,8 +173,9 @@ void eAVSwitch::setSlowblank(int val) printf("cannot open /proc/stb/avs/0/sb\n"); return; } - const char *s = val ? "auto" : "vcr"; - write(fd, s, strlen(s)); + char *sb[] = {"0", "6", "12", "vcr", "auto"}; + write(fd, sb[val], strlen(sb[val])); +// eDebug("set slow blanking to %s", sb[val]); close(fd); } |
