LibC: Implement tcflush(3)
This commit is contained in:
parent
f4ddca0a73
commit
7a27fa3df8
Notes:
sideshowbarker
2024-07-19 04:58:40 +09:00
Author: https://github.com/petelliott Commit: https://github.com/SerenityOS/serenity/commit/7a27fa3df84 Pull-request: https://github.com/SerenityOS/serenity/pull/2758
3 changed files with 11 additions and 3 deletions
|
@ -329,6 +329,14 @@ int TTY::ioctl(FileDescription&, unsigned request, FlatPtr arg)
|
|||
if (request == TCSETSF)
|
||||
flush_input();
|
||||
return 0;
|
||||
case TCFLSH:
|
||||
// Serenity's TTY implementation does not use an output buffer, so ignore TCOFLUSH.
|
||||
if (arg == TCIFLUSH || arg == TCIOFLUSH) {
|
||||
flush_input();
|
||||
} else if (arg != TCOFLUSH) {
|
||||
return -EINVAL;
|
||||
}
|
||||
return 0;
|
||||
case TIOCGWINSZ:
|
||||
ws = reinterpret_cast<winsize*>(arg);
|
||||
if (!current_process.validate_write(ws, sizeof(winsize)))
|
||||
|
|
|
@ -52,6 +52,7 @@ enum IOCtlNumber {
|
|||
TCSETS,
|
||||
TCSETSW,
|
||||
TCSETSF,
|
||||
TCFLSH,
|
||||
TIOCGWINSZ,
|
||||
TIOCSCTTY,
|
||||
TIOCNOTTY,
|
||||
|
@ -75,6 +76,7 @@ enum IOCtlNumber {
|
|||
#define TCSETS TCSETS
|
||||
#define TCSETSW TCSETSW
|
||||
#define TCSETSF TCSETSF
|
||||
#define TCFLSH TCFLSH
|
||||
#define TIOCGWINSZ TIOCGWINSZ
|
||||
#define TIOCSCTTY TIOCSCTTY
|
||||
#define TIOCNOTTY TIOCNOTTY
|
||||
|
|
|
@ -60,9 +60,7 @@ int tcflow(int fd, int action)
|
|||
|
||||
int tcflush(int fd, int queue_selector)
|
||||
{
|
||||
(void)fd;
|
||||
(void)queue_selector;
|
||||
ASSERT_NOT_REACHED();
|
||||
return ioctl(fd, TCFLSH, queue_selector);
|
||||
}
|
||||
|
||||
speed_t cfgetispeed(const struct termios* tp)
|
||||
|
|
Loading…
Add table
Reference in a new issue