%ifndef __ASM_GENERIC_IOCTLS_INC %define __ASM_GENERIC_IOCTLS_INC ; These are the most common definitions for tty ioctl numbers. ; Most of them do not use the recommended _IOC(), but there is ; probably some source code out there hardcoding the number, ; so we might as well use them for all new platforms. ; ; The architectures that use different values here typically ; try to be compatible with some Unix variants for the same ; architecture. ; 0x54 is just a magic number to make these relatively unique ('T') %define TCGETS 0x5401 %define TCSETS 0x5402 %define TCSETSW 0x5403 %define TCSETSF 0x5404 %define TCGETA 0x5405 %define TCSETA 0x5406 %define TCSETAW 0x5407 %define TCSETAF 0x5408 %define TCSBRK 0x5409 %define TCXONC 0x540A %define TCFLSH 0x540B %define TIOCEXCL 0x540C %define TIOCNXCL 0x540D %define TIOCSCTTY 0x540E %define TIOCGPGRP 0x540F %define TIOCSPGRP 0x5410 %define TIOCOUTQ 0x5411 %define TIOCSTI 0x5412 %define TIOCGWINSZ 0x5413 %define TIOCSWINSZ 0x5414 %define TIOCMGET 0x5415 %define TIOCMBIS 0x5416 %define TIOCMBIC 0x5417 %define TIOCMSET 0x5418 %define TIOCGSOFTCAR 0x5419 %define TIOCSSOFTCAR 0x541A %define FIONREAD 0x541B %define TIOCINQ FIONREAD %define TIOCLINUX 0x541C %define TIOCCONS 0x541D %define TIOCGSERIAL 0x541E %define TIOCSSERIAL 0x541F %define TIOCPKT 0x5420 %define FIONBIO 0x5421 %define TIOCNOTTY 0x5422 %define TIOCSETD 0x5423 %define TIOCGETD 0x5424 %define TCSBRKP 0x5425 ; Needed for POSIX tcsendbreak() %define TIOCSBRK 0x5427 ; BSD compatibility %define TIOCCBRK 0x5428 ; BSD compatibility %define TIOCGSID 0x5429 ; Return the session ID of FD ;%define TCGETS2 _IOR('T', 0x2A, struct termios2) ;%define TCSETS2 _IOW('T', 0x2B, struct termios2) ;%define TCSETSW2 _IOW('T', 0x2C, struct termios2) ;%define TCSETSF2 _IOW('T', 0x2D, struct termios2) %define TIOCGRS485 0x542E %ifndef TIOCSRS485 %define TIOCSRS485 0x542F %endif ;%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 TCGETX 0x5432 ; SYS5 TCGETX compatibility %define TCSETX 0x5433 %define TCSETXF 0x5434 %define TCSETXW 0x5435 ;%define TIOCSIG _IOW('T', 0x36, int) ; pty: generate signal %define TIOCVHANGUP 0x5437 ;%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 FIONCLEX 0x5450 %define FIOCLEX 0x5451 %define FIOASYNC 0x5452 %define TIOCSERCONFIG 0x5453 %define TIOCSERGWILD 0x5454 %define TIOCSERSWILD 0x5455 %define TIOCGLCKTRMIOS 0x5456 %define TIOCSLCKTRMIOS 0x5457 %define TIOCSERGSTRUCT 0x5458 ; For debugging only %define TIOCSERGETLSR 0x5459 ; Get line status register %define TIOCSERGETMULTI 0x545A ; Get multiport config %define TIOCSERSETMULTI 0x545B ; Set multiport config %define TIOCMIWAIT 0x545C ; wait for a change on serial input line(s) %define TIOCGICOUNT 0x545D ; read serial port __inline__ interrupt counts ; Some arches already define FIOQSIZE due to a historical ; conflict with a Hayes modem-specific ioctl value. %ifndef FIOQSIZE %define FIOQSIZE 0x5460 %endif ; Used for packet mode %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 TIOCSER_TEMT 0x01 ; Transmitter physically empty ; from bits/ioctls.h ; Routing table calls. %define SIOCADDRT 0x890B ; add routing table entry %define SIOCDELRT 0x890C ; delete routing table entry %define SIOCRTMSG 0x890D ; call to routing system ; Socket configuration controls. %define SIOCGIFNAME 0x8910 ; get iface name %define SIOCSIFLINK 0x8911 ; set iface channel %define SIOCGIFCONF 0x8912 ; get iface list %define SIOCGIFFLAGS 0x8913 ; get flags %define SIOCSIFFLAGS 0x8914 ; set flags %define SIOCGIFADDR 0x8915 ; get PA address %define SIOCSIFADDR 0x8916 ; set PA address %define SIOCGIFDSTADDR 0x8917 ; get remote PA address %define SIOCSIFDSTADDR 0x8918 ; set remote PA address %define SIOCGIFBRDADDR 0x8919 ; get broadcast PA address %define SIOCSIFBRDADDR 0x891a ; set broadcast PA address %define SIOCGIFNETMASK 0x891b ; get network PA mask %define SIOCSIFNETMASK 0x891c ; set network PA mask %define SIOCGIFMETRIC 0x891d ; get metric %define SIOCSIFMETRIC 0x891e ; set metric %define SIOCGIFMEM 0x891f ; get memory address (BSD) %define SIOCSIFMEM 0x8920 ; set memory address (BSD) %define SIOCGIFMTU 0x8921 ; get MTU size %define SIOCSIFMTU 0x8922 ; set MTU size %define SIOCSIFNAME 0x8923 ; set interface name %define SIOCSIFHWADDR 0x8924 ; set hardware address %define SIOCGIFENCAP 0x8925 ; get/set encapsulations %define SIOCSIFENCAP 0x8926 %define SIOCGIFHWADDR 0x8927 ; Get hardware address %define SIOCGIFSLAVE 0x8929 ; Driver slaving support %define SIOCSIFSLAVE 0x8930 %define SIOCADDMULTI 0x8931 ; Multicast address lists %define SIOCDELMULTI 0x8932 %define SIOCGIFINDEX 0x8933 ; name -> if_index mapping %define SIOGIFINDEX SIOCGIFINDEX ; misprint compatibility :-) %define SIOCSIFPFLAGS 0x8934 ; set/get extended flags set %define SIOCGIFPFLAGS 0x8935 %define SIOCDIFADDR 0x8936 ; delete PA address %define SIOCSIFHWBROADCAST 0x8937 ; set hardware broadcast addr %define SIOCGIFCOUNT 0x8938 ; get number of devices %define SIOCGIFBR 0x8940 ; Bridging support %define SIOCSIFBR 0x8941 ; Set bridging options %define SIOCGIFTXQLEN 0x8942 ; Get the tx queue length %define SIOCSIFTXQLEN 0x8943 ; Set the tx queue length ; ARP cache control calls. ; 0x8950 - 0x8952 ; obsolete calls, don't re-use %define SIOCDARP 0x8953 ; delete ARP table entry %define SIOCGARP 0x8954 ; get ARP table entry %define SIOCSARP 0x8955 ; set ARP table entry ; RARP cache control calls. %define SIOCDRARP 0x8960 ; delete RARP table entry %define SIOCGRARP 0x8961 ; get RARP table entry %define SIOCSRARP 0x8962 ; set RARP table entry ; Driver configuration calls %define SIOCGIFMAP 0x8970 ; Get device parameters %define SIOCSIFMAP 0x8971 ; Set device parameters ; DLCI configuration calls %define SIOCADDDLCI 0x8980 ; Create new DLCI device %define SIOCDELDLCI 0x8981 ; Delete DLCI device ; Device private ioctl calls. ; These 16 ioctls are available to devices via the do_ioctl() device ; vector. Each device should include this file and redefine these ; names as their own. Because these are device dependent it is a good ; idea _NOT_ to issue them to random objects and hope. %define SIOCDEVPRIVATE 0x89F0 ; to 89FF ; These 16 ioctl calls are protocol private %define SIOCPROTOPRIVATE 0x89E0 ; to 89EF %endif ; __ASM_GENERIC_IOCTLS_INC