ad8c0eaa0a
Add the ISO7816 ioctl and associated accessors and data structure. Drivers can then use this common implementation to handle ISO7816 (smart cards). Signed-off-by: Nicolas Ferre <nicolas.ferre@microchip.com> [ludovic.desroches@microchip.com: squash and rebase, removal of gpios, checkpatch fixes] Signed-off-by: Ludovic Desroches <ludovic.desroches@microchip.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
131 lines
4.8 KiB
C
131 lines
4.8 KiB
C
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
|
/*
|
|
* include/asm-xtensa/ioctls.h
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
* for more details.
|
|
*
|
|
* Copyright (C) 2003 - 2005 Tensilica Inc.
|
|
*
|
|
* Derived from "include/asm-i386/ioctls.h"
|
|
*/
|
|
|
|
#ifndef _XTENSA_IOCTLS_H
|
|
#define _XTENSA_IOCTLS_H
|
|
|
|
#include <asm/ioctl.h>
|
|
|
|
#define FIOCLEX _IO('f', 1)
|
|
#define FIONCLEX _IO('f', 2)
|
|
#define FIOASYNC _IOW('f', 125, int)
|
|
#define FIONBIO _IOW('f', 126, int)
|
|
#define FIONREAD _IOR('f', 127, int)
|
|
#define TIOCINQ FIONREAD
|
|
#define FIOQSIZE _IOR('f', 128, loff_t)
|
|
|
|
#define TCGETS 0x5401
|
|
#define TCSETS 0x5402
|
|
#define TCSETSW 0x5403
|
|
#define TCSETSF 0x5404
|
|
|
|
#define TCGETA 0x80127417 /* _IOR('t', 23, struct termio) */
|
|
#define TCSETA 0x40127418 /* _IOW('t', 24, struct termio) */
|
|
#define TCSETAW 0x40127419 /* _IOW('t', 25, struct termio) */
|
|
#define TCSETAF 0x4012741C /* _IOW('t', 28, struct termio) */
|
|
|
|
#define TCSBRK _IO('t', 29)
|
|
#define TCXONC _IO('t', 30)
|
|
#define TCFLSH _IO('t', 31)
|
|
|
|
#define TIOCSWINSZ 0x40087467 /* _IOW('t', 103, struct winsize) */
|
|
#define TIOCGWINSZ 0x80087468 /* _IOR('t', 104, struct winsize) */
|
|
#define TIOCSTART _IO('t', 110) /* start output, like ^Q */
|
|
#define TIOCSTOP _IO('t', 111) /* stop output, like ^S */
|
|
#define TIOCOUTQ _IOR('t', 115, int) /* output queue size */
|
|
|
|
#define TIOCSPGRP _IOW('t', 118, int)
|
|
#define TIOCGPGRP _IOR('t', 119, int)
|
|
|
|
#define TIOCEXCL _IO('T', 12)
|
|
#define TIOCNXCL _IO('T', 13)
|
|
#define TIOCSCTTY _IO('T', 14)
|
|
|
|
#define TIOCSTI _IOW('T', 18, char)
|
|
#define TIOCMGET _IOR('T', 21, unsigned int)
|
|
#define TIOCMBIS _IOW('T', 22, unsigned int)
|
|
#define TIOCMBIC _IOW('T', 23, unsigned int)
|
|
#define TIOCMSET _IOW('T', 24, unsigned int)
|
|
# define TIOCM_LE 0x001
|
|
# define TIOCM_DTR 0x002
|
|
# define TIOCM_RTS 0x004
|
|
# define TIOCM_ST 0x008
|
|
# define TIOCM_SR 0x010
|
|
# define TIOCM_CTS 0x020
|
|
# define TIOCM_CAR 0x040
|
|
# define TIOCM_RNG 0x080
|
|
# define TIOCM_DSR 0x100
|
|
# define TIOCM_CD TIOCM_CAR
|
|
# define TIOCM_RI TIOCM_RNG
|
|
|
|
#define TIOCGSOFTCAR _IOR('T', 25, unsigned int)
|
|
#define TIOCSSOFTCAR _IOW('T', 26, unsigned int)
|
|
#define TIOCLINUX _IOW('T', 28, char)
|
|
#define TIOCCONS _IO('T', 29)
|
|
#define TIOCGSERIAL 0x803C541E /*_IOR('T', 30, struct serial_struct)*/
|
|
#define TIOCSSERIAL 0x403C541F /*_IOW('T', 31, struct serial_struct)*/
|
|
#define TIOCPKT _IOW('T', 32, int)
|
|
# define TIOCPKT_DATA 0
|
|
# define TIOCPKT_FLUSHREAD 1
|
|
# define TIOCPKT_FLUSHWRITE 2
|
|
# define TIOCPKT_STOP 4
|
|
# define TIOCPKT_START 8
|
|
# define TIOCPKT_NOSTOP 16
|
|
# define TIOCPKT_DOSTOP 32
|
|
# define TIOCPKT_IOCTL 64
|
|
|
|
|
|
#define TIOCNOTTY _IO('T', 34)
|
|
#define TIOCSETD _IOW('T', 35, int)
|
|
#define TIOCGETD _IOR('T', 36, int)
|
|
#define TCSBRKP _IOW('T', 37, int) /* Needed for POSIX tcsendbreak()*/
|
|
#define TIOCSBRK _IO('T', 39) /* BSD compatibility */
|
|
#define TIOCCBRK _IO('T', 40) /* BSD compatibility */
|
|
#define TIOCGSID _IOR('T', 41, pid_t) /* Return the session ID of FD*/
|
|
#define TCGETS2 _IOR('T', 42, struct termios2)
|
|
#define TCSETS2 _IOW('T', 43, struct termios2)
|
|
#define TCSETSW2 _IOW('T', 44, struct termios2)
|
|
#define TCSETSF2 _IOW('T', 45, struct termios2)
|
|
#define TIOCGRS485 _IOR('T', 46, struct serial_rs485)
|
|
#define TIOCSRS485 _IOWR('T', 47, struct serial_rs485)
|
|
#define TIOCGPTN _IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */
|
|
#define TIOCSPTLCK _IOW('T',0x31, int) /* Lock/unlock Pty */
|
|
#define TIOCGDEV _IOR('T',0x32, unsigned int) /* Get primary device node of /dev/console */
|
|
#define TIOCSIG _IOW('T',0x36, int) /* Generate signal on Pty slave */
|
|
#define TIOCVHANGUP _IO('T', 0x37)
|
|
#define TIOCGPKT _IOR('T', 0x38, int) /* Get packet mode state */
|
|
#define TIOCGPTLCK _IOR('T', 0x39, int) /* Get Pty lock state */
|
|
#define TIOCGEXCL _IOR('T', 0x40, int) /* Get exclusive mode state */
|
|
#define TIOCGPTPEER _IO('T', 0x41) /* Safely open the slave */
|
|
#define TIOCGISO7816 _IOR('T', 0x42, struct serial_iso7816)
|
|
#define TIOCSISO7816 _IOWR('T', 0x43, struct serial_iso7816)
|
|
|
|
#define TIOCSERCONFIG _IO('T', 83)
|
|
#define TIOCSERGWILD _IOR('T', 84, int)
|
|
#define TIOCSERSWILD _IOW('T', 85, int)
|
|
#define TIOCGLCKTRMIOS 0x5456
|
|
#define TIOCSLCKTRMIOS 0x5457
|
|
#define TIOCSERGSTRUCT 0x5458 /* For debugging only */
|
|
#define TIOCSERGETLSR _IOR('T', 89, unsigned int) /* Get line status reg. */
|
|
/* ioctl (fd, TIOCSERGETLSR, &result) where result may be as below */
|
|
# define TIOCSER_TEMT 0x01 /* Transmitter physically empty */
|
|
#define TIOCSERGETMULTI 0x80a8545a /* Get multiport config */
|
|
/* _IOR('T', 90, struct serial_multiport_struct) */
|
|
#define TIOCSERSETMULTI 0x40a8545b /* Set multiport config */
|
|
/* _IOW('T', 91, struct serial_multiport_struct) */
|
|
|
|
#define TIOCMIWAIT _IO('T', 92) /* wait for a change on serial input line(s) */
|
|
#define TIOCGICOUNT 0x545D /* read serial port inline interrupt counts */
|
|
|
|
#endif /* _XTENSA_IOCTLS_H */
|