2016-04-18 17:58:09 -04:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2012, 2014, 2015, 2016 Jonas 'Sortie' Termansen.
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, and distribute this software for any
|
|
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
|
|
* copyright notice and this permission notice appear in all copies.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
*
|
|
|
|
* tty.h
|
|
|
|
* Terminal line discipline.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SORTIX_TTY_H
|
|
|
|
#define SORTIX_TTY_H
|
|
|
|
|
2016-11-15 15:08:41 -05:00
|
|
|
#include <string.h>
|
2016-04-18 17:58:09 -04:00
|
|
|
#include <wchar.h>
|
|
|
|
|
2016-11-15 15:08:41 -05:00
|
|
|
#if !defined(TTY_NAME_MAX)
|
|
|
|
#include <sortix/limits.h>
|
|
|
|
#endif
|
2016-04-18 17:58:09 -04:00
|
|
|
#include <sortix/termios.h>
|
|
|
|
|
|
|
|
#include <sortix/kernel/kthread.h>
|
|
|
|
#include <sortix/kernel/inode.h>
|
|
|
|
#include <sortix/kernel/keyboard.h>
|
|
|
|
#include <sortix/kernel/poll.h>
|
|
|
|
|
|
|
|
#include "kb/kblayout.h"
|
|
|
|
|
|
|
|
#include "linebuffer.h"
|
|
|
|
|
|
|
|
namespace Sortix {
|
|
|
|
|
2016-11-15 15:08:41 -05:00
|
|
|
class DevTTY : public AbstractInode
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DevTTY(dev_t dev, mode_t mode, uid_t owner, gid_t group);
|
|
|
|
virtual ~DevTTY();
|
|
|
|
|
|
|
|
public:
|
|
|
|
virtual Ref<Inode> factory(ioctx_t* ctx, const char* filename, int flags,
|
|
|
|
mode_t mode);
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2016-04-18 17:58:09 -04:00
|
|
|
class TTY : public AbstractInode
|
|
|
|
{
|
|
|
|
public:
|
2016-11-15 15:08:41 -05:00
|
|
|
TTY(dev_t dev, ino_t ino, mode_t mode, uid_t owner, gid_t group,
|
|
|
|
const char* name);
|
2016-04-18 17:58:09 -04:00
|
|
|
virtual ~TTY();
|
|
|
|
|
|
|
|
public:
|
|
|
|
virtual ssize_t read(ioctx_t* ctx, uint8_t* buf, size_t count);
|
|
|
|
virtual ssize_t write(ioctx_t* ctx, const uint8_t* buf, size_t count);
|
|
|
|
virtual int tcgetwincurpos(ioctx_t* ctx, struct wincurpos* wcp);
|
|
|
|
virtual int tcsetpgrp(ioctx_t* ctx, pid_t pgid);
|
|
|
|
virtual pid_t tcgetpgrp(ioctx_t* ctx);
|
|
|
|
virtual int settermmode(ioctx_t* ctx, unsigned termmode);
|
|
|
|
virtual int gettermmode(ioctx_t* ctx, unsigned* termmode);
|
|
|
|
virtual int poll(ioctx_t* ctx, PollNode* node);
|
|
|
|
virtual int tcdrain(ioctx_t* ctx);
|
|
|
|
virtual int tcflow(ioctx_t* ctx, int action);
|
|
|
|
virtual int tcflush(ioctx_t* ctx, int queue_selector);
|
|
|
|
virtual int tcgetattr(ioctx_t* ctx, struct termios* tio);
|
|
|
|
virtual pid_t tcgetsid(ioctx_t* ctx);
|
|
|
|
virtual int tcsendbreak(ioctx_t* ctx, int duration);
|
|
|
|
virtual int tcsetattr(ioctx_t* ctx, int actions, const struct termios* tio);
|
2016-11-15 15:08:41 -05:00
|
|
|
virtual int ioctl(ioctx_t* ctx, int cmd, uintptr_t arg);
|
|
|
|
|
|
|
|
public:
|
|
|
|
void hup();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
void tty_output(const char* str)
|
|
|
|
{
|
|
|
|
tty_output((const unsigned char*) str, strlen(str));
|
|
|
|
}
|
|
|
|
virtual void tty_output(const unsigned char* buffer, size_t length) = 0;
|
2016-04-18 17:58:09 -04:00
|
|
|
|
|
|
|
protected:
|
|
|
|
void ProcessUnicode(uint32_t unicode);
|
|
|
|
void ProcessByte(unsigned char byte, uint32_t control_unicode = 0);
|
|
|
|
void CommitLineBuffer();
|
|
|
|
short PollEventStatus();
|
|
|
|
bool CheckForeground();
|
|
|
|
bool RequireForeground(int sig);
|
2016-11-15 15:08:41 -05:00
|
|
|
bool RequireForegroundUnlocked(int sig);
|
2016-04-18 17:58:09 -04:00
|
|
|
bool CheckHandledByte(tcflag_t lflags, unsigned char key, unsigned char byte);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
PollChannel poll_channel;
|
2016-11-15 15:08:41 -05:00
|
|
|
kthread_mutex_t termlock;
|
2016-04-18 17:58:09 -04:00
|
|
|
kthread_cond_t datacond;
|
|
|
|
mbstate_t read_ps;
|
|
|
|
size_t numeofs;
|
|
|
|
LineBuffer linebuffer;
|
|
|
|
struct termios tio;
|
|
|
|
pid_t foreground_pgid;
|
2016-11-15 15:08:41 -05:00
|
|
|
pid_t sid;
|
|
|
|
bool hungup;
|
|
|
|
char ttyname[TTY_NAME_MAX-5+1];
|
2016-04-18 17:58:09 -04:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Sortix
|
|
|
|
|
|
|
|
#endif
|