diff options
author | Jay Sorg <jay.sorg@gmail.com> | 2013-11-29 16:24:53 -0800 |
---|---|---|
committer | Jay Sorg <jay.sorg@gmail.com> | 2013-11-29 16:24:53 -0800 |
commit | 7ca01ac38143e98d64937437ae77bc27b8f6169c (patch) | |
tree | 08dec2b87d55dfa5aad25b58f5aa3515bd71de0f /xorg/X11R7.6/rdp/rdpinput.c | |
parent | 7dfc25002e52c4d944b39dcc52516af842dc2b11 (diff) | |
download | xrdp-proprietary-7ca01ac38143e98d64937437ae77bc27b8f6169c.tar.gz xrdp-proprietary-7ca01ac38143e98d64937437ae77bc27b8f6169c.zip |
X11rdp: switch to timer for waitpid
Diffstat (limited to 'xorg/X11R7.6/rdp/rdpinput.c')
-rw-r--r-- | xorg/X11R7.6/rdp/rdpinput.c | 80 |
1 files changed, 42 insertions, 38 deletions
diff --git a/xorg/X11R7.6/rdp/rdpinput.c b/xorg/X11R7.6/rdp/rdpinput.c index a2d7eac3..885c8da3 100644 --- a/xorg/X11R7.6/rdp/rdpinput.c +++ b/xorg/X11R7.6/rdp/rdpinput.c @@ -61,7 +61,7 @@ static int g_tab_down = 0; above *_down vars */ static int g_scroll_lock_down = 0; static OsTimerPtr g_kbtimer = 0; - +static OsTimerPtr g_xkbtimer = 0; static OsTimerPtr g_timer = 0; static int g_x = 0; static int g_y = 0; @@ -450,6 +450,44 @@ rdpChangeKeyboardControl(DeviceIntPtr pDev, KeybdCtrl *ctrl) } /******************************************************************************/ +static CARD32 +rdpInDeferredXkbCallback(OsTimerPtr timer, CARD32 now, pointer arg) +{ + int rv_pid; + int pid; + int status; + + LLOGLN(10, ("rdpInDeferredXkbCallback:")); + pid = (int) arg; + rv_pid = waitpid(pid, &status, WNOHANG); + if (rv_pid == -1) + { + if (errno == EINTR) /* signal occurred */ + { + } + else + { + LLOGLN(0, ("rdpInDeferredXkbCallback: waitpid failed")); + } + } + else if (rv_pid == pid) + { + LLOGLN(0, ("rdpInDeferredXkbCallback: setxkbmap result %d", status)); + TimerFree(g_xkbtimer); + g_xkbtimer = 0; + return 0; + } + else if (rv_pid == 0) + { + LLOGLN(0, ("rdpInDeferredXkbCallback: setxkbmap not done yet")); + } + /* try again */ + g_xkbtimer = TimerSet(g_xkbtimer, 0, 1000, + rdpInDeferredXkbCallback, (pointer)(long)pid); + return 0; +} + +/******************************************************************************/ /* 0x00000401 Arabic (101) 0x00000402 Bulgarian @@ -549,10 +587,6 @@ rdpLoadLayout(int keylayout) char a8[16]; int pid; int rv; - int rv_pid; - int status; - int start_time; - int now_time; LLOGLN(10, ("rdpLoadLayout: keylayout 0x%8.8x display %s", keylayout, display)); @@ -608,39 +642,9 @@ rdpLoadLayout(int keylayout) else { /* parent */ - start_time = get_mstime(); - while (1) - { - usleep(1000); - rv_pid = waitpid(pid, &status, WNOHANG); - if (rv_pid == -1) - { - if (errno == EINTR) /* signal occurred */ - { - } - else - { - LLOGLN(0, ("rdpLoadLayout: waitpid failed")); - break; - } - } - else if (rv_pid == pid) - { - rv = 0; - LLOGLN(0, ("rdpLoadLayout: setxkbmap result %d", status)); - break; - } - else - { - LLOGLN(0, ("rdpLoadLayout: waitpid unknown pid return %d", rv)); - } - now_time = get_mstime(); - if (now_time - start_time > 1000 * 1000) - { - LLOGLN(0, ("rdpLoadLayout: waitpid timeout")); - break; - } - } + LLOGLN(0, ("rdpLoadLayout: setxkbmap started pid %d", pid)); + g_xkbtimer = TimerSet(g_xkbtimer, 0, 1000, + rdpInDeferredXkbCallback, (pointer)(long)pid); } return rv; } |