linux/arch/cris/include/asm/termios.h
<<
>>
Prefs
   1#ifndef _CRIS_TERMIOS_H
   2#define _CRIS_TERMIOS_H
   3
   4#include <asm/termbits.h>
   5#include <asm/ioctls.h>
   6#include <asm/rs485.h>
   7#include <linux/serial.h>
   8
   9struct winsize {
  10        unsigned short ws_row;
  11        unsigned short ws_col;
  12        unsigned short ws_xpixel;
  13        unsigned short ws_ypixel;
  14};
  15
  16#define NCC 8
  17struct termio {
  18        unsigned short c_iflag;         /* input mode flags */
  19        unsigned short c_oflag;         /* output mode flags */
  20        unsigned short c_cflag;         /* control mode flags */
  21        unsigned short c_lflag;         /* local mode flags */
  22        unsigned char c_line;           /* line discipline */
  23        unsigned char c_cc[NCC];        /* control characters */
  24};
  25
  26/* modem lines */
  27#define TIOCM_LE        0x001
  28#define TIOCM_DTR       0x002
  29#define TIOCM_RTS       0x004
  30#define TIOCM_ST        0x008
  31#define TIOCM_SR        0x010
  32#define TIOCM_CTS       0x020
  33#define TIOCM_CAR       0x040
  34#define TIOCM_RNG       0x080
  35#define TIOCM_DSR       0x100
  36#define TIOCM_CD        TIOCM_CAR
  37#define TIOCM_RI        TIOCM_RNG
  38#define TIOCM_OUT1      0x2000
  39#define TIOCM_OUT2      0x4000
  40#define TIOCM_LOOP      0x8000
  41
  42/* ioctl (fd, TIOCSERGETLSR, &result) where result may be as below */
  43
  44#ifdef __KERNEL__
  45
  46/*      intr=^C         quit=^\         erase=del       kill=^U
  47        eof=^D          vtime=\0        vmin=\1         sxtc=\0
  48        start=^Q        stop=^S         susp=^Z         eol=\0
  49        reprint=^R      discard=^U      werase=^W       lnext=^V
  50        eol2=\0
  51*/
  52#define INIT_C_CC "\003\034\177\025\004\0\1\0\021\023\032\0\022\017\027\026\0"
  53
  54/*
  55 * Translate a "termio" structure into a "termios". Ugh.
  56 */
  57#define SET_LOW_TERMIOS_BITS(termios, termio, x) { \
  58        unsigned short __tmp; \
  59        get_user(__tmp,&(termio)->x); \
  60        *(unsigned short *) &(termios)->x = __tmp; \
  61}
  62
  63#define user_termio_to_kernel_termios(termios, termio) \
  64({ \
  65        SET_LOW_TERMIOS_BITS(termios, termio, c_iflag); \
  66        SET_LOW_TERMIOS_BITS(termios, termio, c_oflag); \
  67        SET_LOW_TERMIOS_BITS(termios, termio, c_cflag); \
  68        SET_LOW_TERMIOS_BITS(termios, termio, c_lflag); \
  69        copy_from_user((termios)->c_cc, (termio)->c_cc, NCC); \
  70})
  71
  72/*
  73 * Translate a "termios" structure into a "termio". Ugh.
  74 */
  75#define kernel_termios_to_user_termio(termio, termios) \
  76({ \
  77        put_user((termios)->c_iflag, &(termio)->c_iflag); \
  78        put_user((termios)->c_oflag, &(termio)->c_oflag); \
  79        put_user((termios)->c_cflag, &(termio)->c_cflag); \
  80        put_user((termios)->c_lflag, &(termio)->c_lflag); \
  81        put_user((termios)->c_line,  &(termio)->c_line); \
  82        copy_to_user((termio)->c_cc, (termios)->c_cc, NCC); \
  83})
  84
  85#define user_termios_to_kernel_termios(k, u) copy_from_user(k, u, sizeof(struct termios2))
  86#define kernel_termios_to_user_termios(u, k) copy_to_user(u, k, sizeof(struct termios2))
  87#define user_termios_to_kernel_termios_1(k, u) copy_from_user(k, u, sizeof(struct termios))
  88#define kernel_termios_to_user_termios_1(u, k) copy_to_user(u, k, sizeof(struct termios))
  89
  90#endif  /* __KERNEL__ */
  91
  92#endif  /* _CRIS_TERMIOS_H */
  93