lib/driver/rc.cpp,rcinput.cpp: only do EVIOCGRAB when event bit 0x1E is set in event...
[enigma2.git] / lib / driver / rc.cpp
index c56fde4..c1ff13e 100644 (file)
@@ -129,8 +129,11 @@ void eRCInputEventDriver::setExclusive(bool b)
 {
        if (handle >= 0)
        {
+               long evbits;
                int grab = b;
-               if (::ioctl(handle, EVIOCGRAB, grab) < 0)
+               if (::ioctl(handle, EVIOCGBIT(0, EV_MAX+1), &evbits) < 0)
+                       perror("EVIOCGBIT");
+               else if ((evbits & (1 << 0x1E)) && ::ioctl(handle, EVIOCGRAB, grab) < 0)
                        perror("EVIOCGRAB");
        }
 }