blob: 55a9902aeb353d38b978ab0a8f949ef10e4fc57b [file] [log] [blame]
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -07001// cgo -godefs -- -Wall -Werror -static -I/tmp/include -m64 linux/types.go | go run mkpost.go
2// Code generated by the command above; see README.md. DO NOT EDIT.
3
4// +build amd64,linux
5
6package unix
7
8const (
9 SizeofPtr = 0x8
10 SizeofShort = 0x2
11 SizeofInt = 0x4
12 SizeofLong = 0x8
13 SizeofLongLong = 0x8
14 PathMax = 0x1000
15)
16
17type (
18 _C_short int16
19 _C_int int32
20 _C_long int64
21 _C_long_long int64
22)
23
24type Timespec struct {
25 Sec int64
26 Nsec int64
27}
28
29type Timeval struct {
30 Sec int64
31 Usec int64
32}
33
34type Timex struct {
35 Modes uint32
36 Offset int64
37 Freq int64
38 Maxerror int64
39 Esterror int64
40 Status int32
41 Constant int64
42 Precision int64
43 Tolerance int64
44 Time Timeval
45 Tick int64
46 Ppsfreq int64
47 Jitter int64
48 Shift int32
49 Stabil int64
50 Jitcnt int64
51 Calcnt int64
52 Errcnt int64
53 Stbcnt int64
54 Tai int32
55 _ [44]byte
56}
57
Matteo Scandolof9d43412021-01-12 11:11:34 -080058const (
59 TIME_OK = 0x0
60 TIME_INS = 0x1
61 TIME_DEL = 0x2
62 TIME_OOP = 0x3
63 TIME_WAIT = 0x4
64 TIME_ERROR = 0x5
65 TIME_BAD = 0x5
66)
67
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -070068type Time_t int64
69
70type Tms struct {
71 Utime int64
72 Stime int64
73 Cutime int64
74 Cstime int64
75}
76
77type Utimbuf struct {
78 Actime int64
79 Modtime int64
80}
81
82type Rusage struct {
83 Utime Timeval
84 Stime Timeval
85 Maxrss int64
86 Ixrss int64
87 Idrss int64
88 Isrss int64
89 Minflt int64
90 Majflt int64
91 Nswap int64
92 Inblock int64
93 Oublock int64
94 Msgsnd int64
95 Msgrcv int64
96 Nsignals int64
97 Nvcsw int64
98 Nivcsw int64
99}
100
101type Rlimit struct {
102 Cur uint64
103 Max uint64
104}
105
106type _Gid_t uint32
107
108type Stat_t struct {
109 Dev uint64
110 Ino uint64
111 Nlink uint64
112 Mode uint32
113 Uid uint32
114 Gid uint32
115 _ int32
116 Rdev uint64
117 Size int64
118 Blksize int64
119 Blocks int64
120 Atim Timespec
121 Mtim Timespec
122 Ctim Timespec
123 _ [3]int64
124}
125
126type StatxTimestamp struct {
127 Sec int64
128 Nsec uint32
129 _ int32
130}
131
132type Statx_t struct {
133 Mask uint32
134 Blksize uint32
135 Attributes uint64
136 Nlink uint32
137 Uid uint32
138 Gid uint32
139 Mode uint16
140 _ [1]uint16
141 Ino uint64
142 Size uint64
143 Blocks uint64
144 Attributes_mask uint64
145 Atime StatxTimestamp
146 Btime StatxTimestamp
147 Ctime StatxTimestamp
148 Mtime StatxTimestamp
149 Rdev_major uint32
150 Rdev_minor uint32
151 Dev_major uint32
152 Dev_minor uint32
153 _ [14]uint64
154}
155
156type Dirent struct {
157 Ino uint64
158 Off int64
159 Reclen uint16
160 Type uint8
161 Name [256]int8
162 _ [5]byte
163}
164
165type Fsid struct {
166 Val [2]int32
167}
168
169type Flock_t struct {
170 Type int16
171 Whence int16
172 Start int64
173 Len int64
174 Pid int32
175 _ [4]byte
176}
177
178type FscryptPolicy struct {
179 Version uint8
180 Contents_encryption_mode uint8
181 Filenames_encryption_mode uint8
182 Flags uint8
183 Master_key_descriptor [8]uint8
184}
185
186type FscryptKey struct {
187 Mode uint32
188 Raw [64]uint8
189 Size uint32
190}
191
Matteo Scandolof9d43412021-01-12 11:11:34 -0800192type FscryptPolicyV1 struct {
193 Version uint8
194 Contents_encryption_mode uint8
195 Filenames_encryption_mode uint8
196 Flags uint8
197 Master_key_descriptor [8]uint8
198}
199
200type FscryptPolicyV2 struct {
201 Version uint8
202 Contents_encryption_mode uint8
203 Filenames_encryption_mode uint8
204 Flags uint8
205 _ [4]uint8
206 Master_key_identifier [16]uint8
207}
208
209type FscryptGetPolicyExArg struct {
210 Size uint64
211 Policy [24]byte
212}
213
214type FscryptKeySpecifier struct {
215 Type uint32
216 _ uint32
217 U [32]byte
218}
219
220type FscryptAddKeyArg struct {
221 Key_spec FscryptKeySpecifier
222 Raw_size uint32
223 _ [9]uint32
224}
225
226type FscryptRemoveKeyArg struct {
227 Key_spec FscryptKeySpecifier
228 Removal_status_flags uint32
229 _ [5]uint32
230}
231
232type FscryptGetKeyStatusArg struct {
233 Key_spec FscryptKeySpecifier
234 _ [6]uint32
235 Status uint32
236 Status_flags uint32
237 User_count uint32
238 _ [13]uint32
239}
240
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -0700241type KeyctlDHParams struct {
242 Private int32
243 Prime int32
244 Base int32
245}
246
247const (
248 FADV_NORMAL = 0x0
249 FADV_RANDOM = 0x1
250 FADV_SEQUENTIAL = 0x2
251 FADV_WILLNEED = 0x3
252 FADV_DONTNEED = 0x4
253 FADV_NOREUSE = 0x5
254)
255
256type RawSockaddrInet4 struct {
257 Family uint16
258 Port uint16
259 Addr [4]byte /* in_addr */
260 Zero [8]uint8
261}
262
263type RawSockaddrInet6 struct {
264 Family uint16
265 Port uint16
266 Flowinfo uint32
267 Addr [16]byte /* in6_addr */
268 Scope_id uint32
269}
270
271type RawSockaddrUnix struct {
272 Family uint16
273 Path [108]int8
274}
275
276type RawSockaddrLinklayer struct {
277 Family uint16
278 Protocol uint16
279 Ifindex int32
280 Hatype uint16
281 Pkttype uint8
282 Halen uint8
283 Addr [8]uint8
284}
285
286type RawSockaddrNetlink struct {
287 Family uint16
288 Pad uint16
289 Pid uint32
290 Groups uint32
291}
292
293type RawSockaddrHCI struct {
294 Family uint16
295 Dev uint16
296 Channel uint16
297}
298
299type RawSockaddrL2 struct {
300 Family uint16
301 Psm uint16
302 Bdaddr [6]uint8
303 Cid uint16
304 Bdaddr_type uint8
305 _ [1]byte
306}
307
308type RawSockaddrRFCOMM struct {
309 Family uint16
310 Bdaddr [6]uint8
311 Channel uint8
312 _ [1]byte
313}
314
315type RawSockaddrCAN struct {
316 Family uint16
317 Ifindex int32
Matteo Scandolof9d43412021-01-12 11:11:34 -0800318 Addr [16]byte
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -0700319}
320
321type RawSockaddrALG struct {
322 Family uint16
323 Type [14]uint8
324 Feat uint32
325 Mask uint32
326 Name [64]uint8
327}
328
329type RawSockaddrVM struct {
330 Family uint16
331 Reserved1 uint16
332 Port uint32
333 Cid uint32
334 Zero [4]uint8
335}
336
337type RawSockaddrXDP struct {
338 Family uint16
339 Flags uint16
340 Ifindex uint32
341 Queue_id uint32
342 Shared_umem_fd uint32
343}
344
345type RawSockaddrPPPoX [0x1e]byte
346
Matteo Scandolof9d43412021-01-12 11:11:34 -0800347type RawSockaddrTIPC struct {
348 Family uint16
349 Addrtype uint8
350 Scope int8
351 Addr [12]byte
352}
353
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -0700354type RawSockaddr struct {
355 Family uint16
356 Data [14]int8
357}
358
359type RawSockaddrAny struct {
360 Addr RawSockaddr
361 Pad [96]int8
362}
363
364type _Socklen uint32
365
366type Linger struct {
367 Onoff int32
368 Linger int32
369}
370
371type Iovec struct {
372 Base *byte
373 Len uint64
374}
375
376type IPMreq struct {
377 Multiaddr [4]byte /* in_addr */
378 Interface [4]byte /* in_addr */
379}
380
381type IPMreqn struct {
382 Multiaddr [4]byte /* in_addr */
383 Address [4]byte /* in_addr */
384 Ifindex int32
385}
386
387type IPv6Mreq struct {
388 Multiaddr [16]byte /* in6_addr */
389 Interface uint32
390}
391
392type PacketMreq struct {
393 Ifindex int32
394 Type uint16
395 Alen uint16
396 Address [8]uint8
397}
398
399type Msghdr struct {
400 Name *byte
401 Namelen uint32
402 Iov *Iovec
403 Iovlen uint64
404 Control *byte
405 Controllen uint64
406 Flags int32
407 _ [4]byte
408}
409
410type Cmsghdr struct {
411 Len uint64
412 Level int32
413 Type int32
414}
415
416type Inet4Pktinfo struct {
417 Ifindex int32
418 Spec_dst [4]byte /* in_addr */
419 Addr [4]byte /* in_addr */
420}
421
422type Inet6Pktinfo struct {
423 Addr [16]byte /* in6_addr */
424 Ifindex uint32
425}
426
427type IPv6MTUInfo struct {
428 Addr RawSockaddrInet6
429 Mtu uint32
430}
431
432type ICMPv6Filter struct {
433 Data [8]uint32
434}
435
436type Ucred struct {
437 Pid int32
438 Uid uint32
439 Gid uint32
440}
441
442type TCPInfo struct {
443 State uint8
444 Ca_state uint8
445 Retransmits uint8
446 Probes uint8
447 Backoff uint8
448 Options uint8
449 Rto uint32
450 Ato uint32
451 Snd_mss uint32
452 Rcv_mss uint32
453 Unacked uint32
454 Sacked uint32
455 Lost uint32
456 Retrans uint32
457 Fackets uint32
458 Last_data_sent uint32
459 Last_ack_sent uint32
460 Last_data_recv uint32
461 Last_ack_recv uint32
462 Pmtu uint32
463 Rcv_ssthresh uint32
464 Rtt uint32
465 Rttvar uint32
466 Snd_ssthresh uint32
467 Snd_cwnd uint32
468 Advmss uint32
469 Reordering uint32
470 Rcv_rtt uint32
471 Rcv_space uint32
472 Total_retrans uint32
473}
474
475type CanFilter struct {
476 Id uint32
477 Mask uint32
478}
479
480const (
481 SizeofSockaddrInet4 = 0x10
482 SizeofSockaddrInet6 = 0x1c
483 SizeofSockaddrAny = 0x70
484 SizeofSockaddrUnix = 0x6e
485 SizeofSockaddrLinklayer = 0x14
486 SizeofSockaddrNetlink = 0xc
487 SizeofSockaddrHCI = 0x6
488 SizeofSockaddrL2 = 0xe
489 SizeofSockaddrRFCOMM = 0xa
Matteo Scandolof9d43412021-01-12 11:11:34 -0800490 SizeofSockaddrCAN = 0x18
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -0700491 SizeofSockaddrALG = 0x58
492 SizeofSockaddrVM = 0x10
493 SizeofSockaddrXDP = 0x10
494 SizeofSockaddrPPPoX = 0x1e
Matteo Scandolof9d43412021-01-12 11:11:34 -0800495 SizeofSockaddrTIPC = 0x10
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -0700496 SizeofLinger = 0x8
497 SizeofIovec = 0x10
498 SizeofIPMreq = 0x8
499 SizeofIPMreqn = 0xc
500 SizeofIPv6Mreq = 0x14
501 SizeofPacketMreq = 0x10
502 SizeofMsghdr = 0x38
503 SizeofCmsghdr = 0x10
504 SizeofInet4Pktinfo = 0xc
505 SizeofInet6Pktinfo = 0x14
506 SizeofIPv6MTUInfo = 0x20
507 SizeofICMPv6Filter = 0x20
508 SizeofUcred = 0xc
509 SizeofTCPInfo = 0x68
510 SizeofCanFilter = 0x8
511)
512
513const (
514 NDA_UNSPEC = 0x0
515 NDA_DST = 0x1
516 NDA_LLADDR = 0x2
517 NDA_CACHEINFO = 0x3
518 NDA_PROBES = 0x4
519 NDA_VLAN = 0x5
520 NDA_PORT = 0x6
521 NDA_VNI = 0x7
522 NDA_IFINDEX = 0x8
523 NDA_MASTER = 0x9
524 NDA_LINK_NETNSID = 0xa
525 NDA_SRC_VNI = 0xb
526 NTF_USE = 0x1
527 NTF_SELF = 0x2
528 NTF_MASTER = 0x4
529 NTF_PROXY = 0x8
530 NTF_EXT_LEARNED = 0x10
531 NTF_OFFLOADED = 0x20
532 NTF_ROUTER = 0x80
533 NUD_INCOMPLETE = 0x1
534 NUD_REACHABLE = 0x2
535 NUD_STALE = 0x4
536 NUD_DELAY = 0x8
537 NUD_PROBE = 0x10
538 NUD_FAILED = 0x20
539 NUD_NOARP = 0x40
540 NUD_PERMANENT = 0x80
541 NUD_NONE = 0x0
542 IFA_UNSPEC = 0x0
543 IFA_ADDRESS = 0x1
544 IFA_LOCAL = 0x2
545 IFA_LABEL = 0x3
546 IFA_BROADCAST = 0x4
547 IFA_ANYCAST = 0x5
548 IFA_CACHEINFO = 0x6
549 IFA_MULTICAST = 0x7
550 IFA_FLAGS = 0x8
551 IFA_RT_PRIORITY = 0x9
552 IFA_TARGET_NETNSID = 0xa
553 IFLA_UNSPEC = 0x0
554 IFLA_ADDRESS = 0x1
555 IFLA_BROADCAST = 0x2
556 IFLA_IFNAME = 0x3
557 IFLA_MTU = 0x4
558 IFLA_LINK = 0x5
559 IFLA_QDISC = 0x6
560 IFLA_STATS = 0x7
561 IFLA_COST = 0x8
562 IFLA_PRIORITY = 0x9
563 IFLA_MASTER = 0xa
564 IFLA_WIRELESS = 0xb
565 IFLA_PROTINFO = 0xc
566 IFLA_TXQLEN = 0xd
567 IFLA_MAP = 0xe
568 IFLA_WEIGHT = 0xf
569 IFLA_OPERSTATE = 0x10
570 IFLA_LINKMODE = 0x11
571 IFLA_LINKINFO = 0x12
572 IFLA_NET_NS_PID = 0x13
573 IFLA_IFALIAS = 0x14
574 IFLA_NUM_VF = 0x15
575 IFLA_VFINFO_LIST = 0x16
576 IFLA_STATS64 = 0x17
577 IFLA_VF_PORTS = 0x18
578 IFLA_PORT_SELF = 0x19
579 IFLA_AF_SPEC = 0x1a
580 IFLA_GROUP = 0x1b
581 IFLA_NET_NS_FD = 0x1c
582 IFLA_EXT_MASK = 0x1d
583 IFLA_PROMISCUITY = 0x1e
584 IFLA_NUM_TX_QUEUES = 0x1f
585 IFLA_NUM_RX_QUEUES = 0x20
586 IFLA_CARRIER = 0x21
587 IFLA_PHYS_PORT_ID = 0x22
588 IFLA_CARRIER_CHANGES = 0x23
589 IFLA_PHYS_SWITCH_ID = 0x24
590 IFLA_LINK_NETNSID = 0x25
591 IFLA_PHYS_PORT_NAME = 0x26
592 IFLA_PROTO_DOWN = 0x27
593 IFLA_GSO_MAX_SEGS = 0x28
594 IFLA_GSO_MAX_SIZE = 0x29
595 IFLA_PAD = 0x2a
596 IFLA_XDP = 0x2b
597 IFLA_EVENT = 0x2c
598 IFLA_NEW_NETNSID = 0x2d
599 IFLA_IF_NETNSID = 0x2e
600 IFLA_TARGET_NETNSID = 0x2e
601 IFLA_CARRIER_UP_COUNT = 0x2f
602 IFLA_CARRIER_DOWN_COUNT = 0x30
603 IFLA_NEW_IFINDEX = 0x31
604 IFLA_MIN_MTU = 0x32
605 IFLA_MAX_MTU = 0x33
Matteo Scandolof9d43412021-01-12 11:11:34 -0800606 IFLA_MAX = 0x35
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -0700607 IFLA_INFO_KIND = 0x1
608 IFLA_INFO_DATA = 0x2
609 IFLA_INFO_XSTATS = 0x3
610 IFLA_INFO_SLAVE_KIND = 0x4
611 IFLA_INFO_SLAVE_DATA = 0x5
612 RT_SCOPE_UNIVERSE = 0x0
613 RT_SCOPE_SITE = 0xc8
614 RT_SCOPE_LINK = 0xfd
615 RT_SCOPE_HOST = 0xfe
616 RT_SCOPE_NOWHERE = 0xff
617 RT_TABLE_UNSPEC = 0x0
618 RT_TABLE_COMPAT = 0xfc
619 RT_TABLE_DEFAULT = 0xfd
620 RT_TABLE_MAIN = 0xfe
621 RT_TABLE_LOCAL = 0xff
622 RT_TABLE_MAX = 0xffffffff
623 RTA_UNSPEC = 0x0
624 RTA_DST = 0x1
625 RTA_SRC = 0x2
626 RTA_IIF = 0x3
627 RTA_OIF = 0x4
628 RTA_GATEWAY = 0x5
629 RTA_PRIORITY = 0x6
630 RTA_PREFSRC = 0x7
631 RTA_METRICS = 0x8
632 RTA_MULTIPATH = 0x9
633 RTA_FLOW = 0xb
634 RTA_CACHEINFO = 0xc
635 RTA_TABLE = 0xf
636 RTA_MARK = 0x10
637 RTA_MFC_STATS = 0x11
638 RTA_VIA = 0x12
639 RTA_NEWDST = 0x13
640 RTA_PREF = 0x14
641 RTA_ENCAP_TYPE = 0x15
642 RTA_ENCAP = 0x16
643 RTA_EXPIRES = 0x17
644 RTA_PAD = 0x18
645 RTA_UID = 0x19
646 RTA_TTL_PROPAGATE = 0x1a
647 RTA_IP_PROTO = 0x1b
648 RTA_SPORT = 0x1c
649 RTA_DPORT = 0x1d
650 RTN_UNSPEC = 0x0
651 RTN_UNICAST = 0x1
652 RTN_LOCAL = 0x2
653 RTN_BROADCAST = 0x3
654 RTN_ANYCAST = 0x4
655 RTN_MULTICAST = 0x5
656 RTN_BLACKHOLE = 0x6
657 RTN_UNREACHABLE = 0x7
658 RTN_PROHIBIT = 0x8
659 RTN_THROW = 0x9
660 RTN_NAT = 0xa
661 RTN_XRESOLVE = 0xb
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -0700662 SizeofNlMsghdr = 0x10
663 SizeofNlMsgerr = 0x14
664 SizeofRtGenmsg = 0x1
665 SizeofNlAttr = 0x4
666 SizeofRtAttr = 0x4
667 SizeofIfInfomsg = 0x10
668 SizeofIfAddrmsg = 0x8
Matteo Scandolof9d43412021-01-12 11:11:34 -0800669 SizeofIfaCacheinfo = 0x10
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -0700670 SizeofRtMsg = 0xc
671 SizeofRtNexthop = 0x8
672 SizeofNdUseroptmsg = 0x10
673 SizeofNdMsg = 0xc
674)
675
676type NlMsghdr struct {
677 Len uint32
678 Type uint16
679 Flags uint16
680 Seq uint32
681 Pid uint32
682}
683
684type NlMsgerr struct {
685 Error int32
686 Msg NlMsghdr
687}
688
689type RtGenmsg struct {
690 Family uint8
691}
692
693type NlAttr struct {
694 Len uint16
695 Type uint16
696}
697
698type RtAttr struct {
699 Len uint16
700 Type uint16
701}
702
703type IfInfomsg struct {
704 Family uint8
705 _ uint8
706 Type uint16
707 Index int32
708 Flags uint32
709 Change uint32
710}
711
712type IfAddrmsg struct {
713 Family uint8
714 Prefixlen uint8
715 Flags uint8
716 Scope uint8
717 Index uint32
718}
719
Matteo Scandolof9d43412021-01-12 11:11:34 -0800720type IfaCacheinfo struct {
721 Prefered uint32
722 Valid uint32
723 Cstamp uint32
724 Tstamp uint32
725}
726
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -0700727type RtMsg struct {
728 Family uint8
729 Dst_len uint8
730 Src_len uint8
731 Tos uint8
732 Table uint8
733 Protocol uint8
734 Scope uint8
735 Type uint8
736 Flags uint32
737}
738
739type RtNexthop struct {
740 Len uint16
741 Flags uint8
742 Hops uint8
743 Ifindex int32
744}
745
746type NdUseroptmsg struct {
747 Family uint8
748 Pad1 uint8
749 Opts_len uint16
750 Ifindex int32
751 Icmp_type uint8
752 Icmp_code uint8
753 Pad2 uint16
754 Pad3 uint32
755}
756
757type NdMsg struct {
758 Family uint8
759 Pad1 uint8
760 Pad2 uint16
761 Ifindex int32
762 State uint16
763 Flags uint8
764 Type uint8
765}
766
767const (
768 SizeofSockFilter = 0x8
769 SizeofSockFprog = 0x10
770)
771
772type SockFilter struct {
773 Code uint16
774 Jt uint8
775 Jf uint8
776 K uint32
777}
778
779type SockFprog struct {
780 Len uint16
781 Filter *SockFilter
782}
783
784type InotifyEvent struct {
785 Wd int32
786 Mask uint32
787 Cookie uint32
788 Len uint32
789}
790
791const SizeofInotifyEvent = 0x10
792
793type PtraceRegs struct {
794 R15 uint64
795 R14 uint64
796 R13 uint64
797 R12 uint64
798 Rbp uint64
799 Rbx uint64
800 R11 uint64
801 R10 uint64
802 R9 uint64
803 R8 uint64
804 Rax uint64
805 Rcx uint64
806 Rdx uint64
807 Rsi uint64
808 Rdi uint64
809 Orig_rax uint64
810 Rip uint64
811 Cs uint64
812 Eflags uint64
813 Rsp uint64
814 Ss uint64
815 Fs_base uint64
816 Gs_base uint64
817 Ds uint64
818 Es uint64
819 Fs uint64
820 Gs uint64
821}
822
823type FdSet struct {
824 Bits [16]int64
825}
826
827type Sysinfo_t struct {
828 Uptime int64
829 Loads [3]uint64
830 Totalram uint64
831 Freeram uint64
832 Sharedram uint64
833 Bufferram uint64
834 Totalswap uint64
835 Freeswap uint64
836 Procs uint16
837 Pad uint16
838 Totalhigh uint64
839 Freehigh uint64
840 Unit uint32
841 _ [0]int8
842 _ [4]byte
843}
844
845type Utsname struct {
846 Sysname [65]byte
847 Nodename [65]byte
848 Release [65]byte
849 Version [65]byte
850 Machine [65]byte
851 Domainname [65]byte
852}
853
854type Ustat_t struct {
855 Tfree int32
856 Tinode uint64
857 Fname [6]int8
858 Fpack [6]int8
859 _ [4]byte
860}
861
862type EpollEvent struct {
863 Events uint32
864 Fd int32
865 Pad int32
866}
867
868const (
869 AT_EMPTY_PATH = 0x1000
870 AT_FDCWD = -0x64
871 AT_NO_AUTOMOUNT = 0x800
872 AT_REMOVEDIR = 0x200
873
874 AT_STATX_SYNC_AS_STAT = 0x0
875 AT_STATX_FORCE_SYNC = 0x2000
876 AT_STATX_DONT_SYNC = 0x4000
877
878 AT_SYMLINK_FOLLOW = 0x400
879 AT_SYMLINK_NOFOLLOW = 0x100
880
881 AT_EACCESS = 0x200
882)
883
884type PollFd struct {
885 Fd int32
886 Events int16
887 Revents int16
888}
889
890const (
891 POLLIN = 0x1
892 POLLPRI = 0x2
893 POLLOUT = 0x4
894 POLLRDHUP = 0x2000
895 POLLERR = 0x8
896 POLLHUP = 0x10
897 POLLNVAL = 0x20
898)
899
900type Sigset_t struct {
901 Val [16]uint64
902}
903
Matteo Scandolof9d43412021-01-12 11:11:34 -0800904const _C__NSIG = 0x41
905
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -0700906type SignalfdSiginfo struct {
907 Signo uint32
908 Errno int32
909 Code int32
910 Pid uint32
911 Uid uint32
912 Fd int32
913 Tid uint32
914 Band uint32
915 Overrun uint32
916 Trapno uint32
917 Status int32
918 Int int32
919 Ptr uint64
920 Utime uint64
921 Stime uint64
922 Addr uint64
923 Addr_lsb uint16
924 _ uint16
925 Syscall int32
926 Call_addr uint64
927 Arch uint32
928 _ [28]uint8
929}
930
931const PERF_IOC_FLAG_GROUP = 0x1
932
933type Termios struct {
934 Iflag uint32
935 Oflag uint32
936 Cflag uint32
937 Lflag uint32
938 Line uint8
939 Cc [19]uint8
940 Ispeed uint32
941 Ospeed uint32
942}
943
944type Winsize struct {
945 Row uint16
946 Col uint16
947 Xpixel uint16
948 Ypixel uint16
949}
950
951type Taskstats struct {
952 Version uint16
953 Ac_exitcode uint32
954 Ac_flag uint8
955 Ac_nice uint8
956 Cpu_count uint64
957 Cpu_delay_total uint64
958 Blkio_count uint64
959 Blkio_delay_total uint64
960 Swapin_count uint64
961 Swapin_delay_total uint64
962 Cpu_run_real_total uint64
963 Cpu_run_virtual_total uint64
964 Ac_comm [32]int8
965 Ac_sched uint8
966 Ac_pad [3]uint8
967 _ [4]byte
968 Ac_uid uint32
969 Ac_gid uint32
970 Ac_pid uint32
971 Ac_ppid uint32
972 Ac_btime uint32
973 Ac_etime uint64
974 Ac_utime uint64
975 Ac_stime uint64
976 Ac_minflt uint64
977 Ac_majflt uint64
978 Coremem uint64
979 Virtmem uint64
980 Hiwater_rss uint64
981 Hiwater_vm uint64
982 Read_char uint64
983 Write_char uint64
984 Read_syscalls uint64
985 Write_syscalls uint64
986 Read_bytes uint64
987 Write_bytes uint64
988 Cancelled_write_bytes uint64
989 Nvcsw uint64
990 Nivcsw uint64
991 Ac_utimescaled uint64
992 Ac_stimescaled uint64
993 Cpu_scaled_run_real_total uint64
994 Freepages_count uint64
995 Freepages_delay_total uint64
996 Thrashing_count uint64
997 Thrashing_delay_total uint64
998}
999
1000const (
1001 TASKSTATS_CMD_UNSPEC = 0x0
1002 TASKSTATS_CMD_GET = 0x1
1003 TASKSTATS_CMD_NEW = 0x2
1004 TASKSTATS_TYPE_UNSPEC = 0x0
1005 TASKSTATS_TYPE_PID = 0x1
1006 TASKSTATS_TYPE_TGID = 0x2
1007 TASKSTATS_TYPE_STATS = 0x3
1008 TASKSTATS_TYPE_AGGR_PID = 0x4
1009 TASKSTATS_TYPE_AGGR_TGID = 0x5
1010 TASKSTATS_TYPE_NULL = 0x6
1011 TASKSTATS_CMD_ATTR_UNSPEC = 0x0
1012 TASKSTATS_CMD_ATTR_PID = 0x1
1013 TASKSTATS_CMD_ATTR_TGID = 0x2
1014 TASKSTATS_CMD_ATTR_REGISTER_CPUMASK = 0x3
1015 TASKSTATS_CMD_ATTR_DEREGISTER_CPUMASK = 0x4
1016)
1017
1018type CGroupStats struct {
1019 Sleeping uint64
1020 Running uint64
1021 Stopped uint64
1022 Uninterruptible uint64
1023 Io_wait uint64
1024}
1025
1026const (
1027 CGROUPSTATS_CMD_UNSPEC = 0x3
1028 CGROUPSTATS_CMD_GET = 0x4
1029 CGROUPSTATS_CMD_NEW = 0x5
1030 CGROUPSTATS_TYPE_UNSPEC = 0x0
1031 CGROUPSTATS_TYPE_CGROUP_STATS = 0x1
1032 CGROUPSTATS_CMD_ATTR_UNSPEC = 0x0
1033 CGROUPSTATS_CMD_ATTR_FD = 0x1
1034)
1035
1036type Genlmsghdr struct {
1037 Cmd uint8
1038 Version uint8
1039 Reserved uint16
1040}
1041
1042const (
1043 CTRL_CMD_UNSPEC = 0x0
1044 CTRL_CMD_NEWFAMILY = 0x1
1045 CTRL_CMD_DELFAMILY = 0x2
1046 CTRL_CMD_GETFAMILY = 0x3
1047 CTRL_CMD_NEWOPS = 0x4
1048 CTRL_CMD_DELOPS = 0x5
1049 CTRL_CMD_GETOPS = 0x6
1050 CTRL_CMD_NEWMCAST_GRP = 0x7
1051 CTRL_CMD_DELMCAST_GRP = 0x8
1052 CTRL_CMD_GETMCAST_GRP = 0x9
1053 CTRL_ATTR_UNSPEC = 0x0
1054 CTRL_ATTR_FAMILY_ID = 0x1
1055 CTRL_ATTR_FAMILY_NAME = 0x2
1056 CTRL_ATTR_VERSION = 0x3
1057 CTRL_ATTR_HDRSIZE = 0x4
1058 CTRL_ATTR_MAXATTR = 0x5
1059 CTRL_ATTR_OPS = 0x6
1060 CTRL_ATTR_MCAST_GROUPS = 0x7
1061 CTRL_ATTR_OP_UNSPEC = 0x0
1062 CTRL_ATTR_OP_ID = 0x1
1063 CTRL_ATTR_OP_FLAGS = 0x2
1064 CTRL_ATTR_MCAST_GRP_UNSPEC = 0x0
1065 CTRL_ATTR_MCAST_GRP_NAME = 0x1
1066 CTRL_ATTR_MCAST_GRP_ID = 0x2
1067)
1068
1069type cpuMask uint64
1070
1071const (
1072 _CPU_SETSIZE = 0x400
1073 _NCPUBITS = 0x40
1074)
1075
1076const (
1077 BDADDR_BREDR = 0x0
1078 BDADDR_LE_PUBLIC = 0x1
1079 BDADDR_LE_RANDOM = 0x2
1080)
1081
1082type PerfEventAttr struct {
1083 Type uint32
1084 Size uint32
1085 Config uint64
1086 Sample uint64
1087 Sample_type uint64
1088 Read_format uint64
1089 Bits uint64
1090 Wakeup uint32
1091 Bp_type uint32
1092 Ext1 uint64
1093 Ext2 uint64
1094 Branch_sample_type uint64
1095 Sample_regs_user uint64
1096 Sample_stack_user uint32
1097 Clockid int32
1098 Sample_regs_intr uint64
1099 Aux_watermark uint32
1100 Sample_max_stack uint16
1101 _ uint16
1102}
1103
1104type PerfEventMmapPage struct {
1105 Version uint32
1106 Compat_version uint32
1107 Lock uint32
1108 Index uint32
1109 Offset int64
1110 Time_enabled uint64
1111 Time_running uint64
1112 Capabilities uint64
1113 Pmc_width uint16
1114 Time_shift uint16
1115 Time_mult uint32
1116 Time_offset uint64
1117 Time_zero uint64
1118 Size uint32
1119 _ [948]uint8
1120 Data_head uint64
1121 Data_tail uint64
1122 Data_offset uint64
1123 Data_size uint64
1124 Aux_head uint64
1125 Aux_tail uint64
1126 Aux_offset uint64
1127 Aux_size uint64
1128}
1129
1130const (
1131 PerfBitDisabled uint64 = CBitFieldMaskBit0
1132 PerfBitInherit = CBitFieldMaskBit1
1133 PerfBitPinned = CBitFieldMaskBit2
1134 PerfBitExclusive = CBitFieldMaskBit3
1135 PerfBitExcludeUser = CBitFieldMaskBit4
1136 PerfBitExcludeKernel = CBitFieldMaskBit5
1137 PerfBitExcludeHv = CBitFieldMaskBit6
1138 PerfBitExcludeIdle = CBitFieldMaskBit7
1139 PerfBitMmap = CBitFieldMaskBit8
1140 PerfBitComm = CBitFieldMaskBit9
1141 PerfBitFreq = CBitFieldMaskBit10
1142 PerfBitInheritStat = CBitFieldMaskBit11
1143 PerfBitEnableOnExec = CBitFieldMaskBit12
1144 PerfBitTask = CBitFieldMaskBit13
1145 PerfBitWatermark = CBitFieldMaskBit14
1146 PerfBitPreciseIPBit1 = CBitFieldMaskBit15
1147 PerfBitPreciseIPBit2 = CBitFieldMaskBit16
1148 PerfBitMmapData = CBitFieldMaskBit17
1149 PerfBitSampleIDAll = CBitFieldMaskBit18
1150 PerfBitExcludeHost = CBitFieldMaskBit19
1151 PerfBitExcludeGuest = CBitFieldMaskBit20
1152 PerfBitExcludeCallchainKernel = CBitFieldMaskBit21
1153 PerfBitExcludeCallchainUser = CBitFieldMaskBit22
1154 PerfBitMmap2 = CBitFieldMaskBit23
1155 PerfBitCommExec = CBitFieldMaskBit24
1156 PerfBitUseClockID = CBitFieldMaskBit25
1157 PerfBitContextSwitch = CBitFieldMaskBit26
1158)
1159
1160const (
1161 PERF_TYPE_HARDWARE = 0x0
1162 PERF_TYPE_SOFTWARE = 0x1
1163 PERF_TYPE_TRACEPOINT = 0x2
1164 PERF_TYPE_HW_CACHE = 0x3
1165 PERF_TYPE_RAW = 0x4
1166 PERF_TYPE_BREAKPOINT = 0x5
1167
1168 PERF_COUNT_HW_CPU_CYCLES = 0x0
1169 PERF_COUNT_HW_INSTRUCTIONS = 0x1
1170 PERF_COUNT_HW_CACHE_REFERENCES = 0x2
1171 PERF_COUNT_HW_CACHE_MISSES = 0x3
1172 PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4
1173 PERF_COUNT_HW_BRANCH_MISSES = 0x5
1174 PERF_COUNT_HW_BUS_CYCLES = 0x6
1175 PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7
1176 PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8
1177 PERF_COUNT_HW_REF_CPU_CYCLES = 0x9
1178
1179 PERF_COUNT_HW_CACHE_L1D = 0x0
1180 PERF_COUNT_HW_CACHE_L1I = 0x1
1181 PERF_COUNT_HW_CACHE_LL = 0x2
1182 PERF_COUNT_HW_CACHE_DTLB = 0x3
1183 PERF_COUNT_HW_CACHE_ITLB = 0x4
1184 PERF_COUNT_HW_CACHE_BPU = 0x5
1185 PERF_COUNT_HW_CACHE_NODE = 0x6
1186
1187 PERF_COUNT_HW_CACHE_OP_READ = 0x0
1188 PERF_COUNT_HW_CACHE_OP_WRITE = 0x1
1189 PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2
1190
1191 PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0
1192 PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1
1193
1194 PERF_COUNT_SW_CPU_CLOCK = 0x0
1195 PERF_COUNT_SW_TASK_CLOCK = 0x1
1196 PERF_COUNT_SW_PAGE_FAULTS = 0x2
1197 PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3
1198 PERF_COUNT_SW_CPU_MIGRATIONS = 0x4
1199 PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5
1200 PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6
1201 PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7
1202 PERF_COUNT_SW_EMULATION_FAULTS = 0x8
1203 PERF_COUNT_SW_DUMMY = 0x9
1204 PERF_COUNT_SW_BPF_OUTPUT = 0xa
1205
1206 PERF_SAMPLE_IP = 0x1
1207 PERF_SAMPLE_TID = 0x2
1208 PERF_SAMPLE_TIME = 0x4
1209 PERF_SAMPLE_ADDR = 0x8
1210 PERF_SAMPLE_READ = 0x10
1211 PERF_SAMPLE_CALLCHAIN = 0x20
1212 PERF_SAMPLE_ID = 0x40
1213 PERF_SAMPLE_CPU = 0x80
1214 PERF_SAMPLE_PERIOD = 0x100
1215 PERF_SAMPLE_STREAM_ID = 0x200
1216 PERF_SAMPLE_RAW = 0x400
1217 PERF_SAMPLE_BRANCH_STACK = 0x800
1218
1219 PERF_SAMPLE_BRANCH_USER = 0x1
1220 PERF_SAMPLE_BRANCH_KERNEL = 0x2
1221 PERF_SAMPLE_BRANCH_HV = 0x4
1222 PERF_SAMPLE_BRANCH_ANY = 0x8
1223 PERF_SAMPLE_BRANCH_ANY_CALL = 0x10
1224 PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20
1225 PERF_SAMPLE_BRANCH_IND_CALL = 0x40
1226 PERF_SAMPLE_BRANCH_ABORT_TX = 0x80
1227 PERF_SAMPLE_BRANCH_IN_TX = 0x100
1228 PERF_SAMPLE_BRANCH_NO_TX = 0x200
1229 PERF_SAMPLE_BRANCH_COND = 0x400
1230 PERF_SAMPLE_BRANCH_CALL_STACK = 0x800
1231 PERF_SAMPLE_BRANCH_IND_JUMP = 0x1000
1232 PERF_SAMPLE_BRANCH_CALL = 0x2000
1233 PERF_SAMPLE_BRANCH_NO_FLAGS = 0x4000
1234 PERF_SAMPLE_BRANCH_NO_CYCLES = 0x8000
1235 PERF_SAMPLE_BRANCH_TYPE_SAVE = 0x10000
1236
1237 PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1
1238 PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2
1239 PERF_FORMAT_ID = 0x4
1240 PERF_FORMAT_GROUP = 0x8
1241
1242 PERF_RECORD_MMAP = 0x1
1243 PERF_RECORD_LOST = 0x2
1244 PERF_RECORD_COMM = 0x3
1245 PERF_RECORD_EXIT = 0x4
1246 PERF_RECORD_THROTTLE = 0x5
1247 PERF_RECORD_UNTHROTTLE = 0x6
1248 PERF_RECORD_FORK = 0x7
1249 PERF_RECORD_READ = 0x8
1250 PERF_RECORD_SAMPLE = 0x9
1251 PERF_RECORD_MMAP2 = 0xa
1252 PERF_RECORD_AUX = 0xb
1253 PERF_RECORD_ITRACE_START = 0xc
1254 PERF_RECORD_LOST_SAMPLES = 0xd
1255 PERF_RECORD_SWITCH = 0xe
1256 PERF_RECORD_SWITCH_CPU_WIDE = 0xf
1257 PERF_RECORD_NAMESPACES = 0x10
1258
1259 PERF_CONTEXT_HV = -0x20
1260 PERF_CONTEXT_KERNEL = -0x80
1261 PERF_CONTEXT_USER = -0x200
1262
1263 PERF_CONTEXT_GUEST = -0x800
1264 PERF_CONTEXT_GUEST_KERNEL = -0x880
1265 PERF_CONTEXT_GUEST_USER = -0xa00
1266
1267 PERF_FLAG_FD_NO_GROUP = 0x1
1268 PERF_FLAG_FD_OUTPUT = 0x2
1269 PERF_FLAG_PID_CGROUP = 0x4
1270 PERF_FLAG_FD_CLOEXEC = 0x8
1271)
1272
1273const (
1274 CBitFieldMaskBit0 = 0x1
1275 CBitFieldMaskBit1 = 0x2
1276 CBitFieldMaskBit2 = 0x4
1277 CBitFieldMaskBit3 = 0x8
1278 CBitFieldMaskBit4 = 0x10
1279 CBitFieldMaskBit5 = 0x20
1280 CBitFieldMaskBit6 = 0x40
1281 CBitFieldMaskBit7 = 0x80
1282 CBitFieldMaskBit8 = 0x100
1283 CBitFieldMaskBit9 = 0x200
1284 CBitFieldMaskBit10 = 0x400
1285 CBitFieldMaskBit11 = 0x800
1286 CBitFieldMaskBit12 = 0x1000
1287 CBitFieldMaskBit13 = 0x2000
1288 CBitFieldMaskBit14 = 0x4000
1289 CBitFieldMaskBit15 = 0x8000
1290 CBitFieldMaskBit16 = 0x10000
1291 CBitFieldMaskBit17 = 0x20000
1292 CBitFieldMaskBit18 = 0x40000
1293 CBitFieldMaskBit19 = 0x80000
1294 CBitFieldMaskBit20 = 0x100000
1295 CBitFieldMaskBit21 = 0x200000
1296 CBitFieldMaskBit22 = 0x400000
1297 CBitFieldMaskBit23 = 0x800000
1298 CBitFieldMaskBit24 = 0x1000000
1299 CBitFieldMaskBit25 = 0x2000000
1300 CBitFieldMaskBit26 = 0x4000000
1301 CBitFieldMaskBit27 = 0x8000000
1302 CBitFieldMaskBit28 = 0x10000000
1303 CBitFieldMaskBit29 = 0x20000000
1304 CBitFieldMaskBit30 = 0x40000000
1305 CBitFieldMaskBit31 = 0x80000000
1306 CBitFieldMaskBit32 = 0x100000000
1307 CBitFieldMaskBit33 = 0x200000000
1308 CBitFieldMaskBit34 = 0x400000000
1309 CBitFieldMaskBit35 = 0x800000000
1310 CBitFieldMaskBit36 = 0x1000000000
1311 CBitFieldMaskBit37 = 0x2000000000
1312 CBitFieldMaskBit38 = 0x4000000000
1313 CBitFieldMaskBit39 = 0x8000000000
1314 CBitFieldMaskBit40 = 0x10000000000
1315 CBitFieldMaskBit41 = 0x20000000000
1316 CBitFieldMaskBit42 = 0x40000000000
1317 CBitFieldMaskBit43 = 0x80000000000
1318 CBitFieldMaskBit44 = 0x100000000000
1319 CBitFieldMaskBit45 = 0x200000000000
1320 CBitFieldMaskBit46 = 0x400000000000
1321 CBitFieldMaskBit47 = 0x800000000000
1322 CBitFieldMaskBit48 = 0x1000000000000
1323 CBitFieldMaskBit49 = 0x2000000000000
1324 CBitFieldMaskBit50 = 0x4000000000000
1325 CBitFieldMaskBit51 = 0x8000000000000
1326 CBitFieldMaskBit52 = 0x10000000000000
1327 CBitFieldMaskBit53 = 0x20000000000000
1328 CBitFieldMaskBit54 = 0x40000000000000
1329 CBitFieldMaskBit55 = 0x80000000000000
1330 CBitFieldMaskBit56 = 0x100000000000000
1331 CBitFieldMaskBit57 = 0x200000000000000
1332 CBitFieldMaskBit58 = 0x400000000000000
1333 CBitFieldMaskBit59 = 0x800000000000000
1334 CBitFieldMaskBit60 = 0x1000000000000000
1335 CBitFieldMaskBit61 = 0x2000000000000000
1336 CBitFieldMaskBit62 = 0x4000000000000000
1337 CBitFieldMaskBit63 = 0x8000000000000000
1338)
1339
1340type SockaddrStorage struct {
1341 Family uint16
1342 _ [118]int8
1343 _ uint64
1344}
1345
1346type TCPMD5Sig struct {
1347 Addr SockaddrStorage
1348 Flags uint8
1349 Prefixlen uint8
1350 Keylen uint16
1351 _ uint32
1352 Key [80]uint8
1353}
1354
1355type HDDriveCmdHdr struct {
1356 Command uint8
1357 Number uint8
1358 Feature uint8
1359 Count uint8
1360}
1361
1362type HDGeometry struct {
1363 Heads uint8
1364 Sectors uint8
1365 Cylinders uint16
1366 Start uint64
1367}
1368
1369type HDDriveID struct {
1370 Config uint16
1371 Cyls uint16
1372 Reserved2 uint16
1373 Heads uint16
1374 Track_bytes uint16
1375 Sector_bytes uint16
1376 Sectors uint16
1377 Vendor0 uint16
1378 Vendor1 uint16
1379 Vendor2 uint16
1380 Serial_no [20]uint8
1381 Buf_type uint16
1382 Buf_size uint16
1383 Ecc_bytes uint16
1384 Fw_rev [8]uint8
1385 Model [40]uint8
1386 Max_multsect uint8
1387 Vendor3 uint8
1388 Dword_io uint16
1389 Vendor4 uint8
1390 Capability uint8
1391 Reserved50 uint16
1392 Vendor5 uint8
1393 TPIO uint8
1394 Vendor6 uint8
1395 TDMA uint8
1396 Field_valid uint16
1397 Cur_cyls uint16
1398 Cur_heads uint16
1399 Cur_sectors uint16
1400 Cur_capacity0 uint16
1401 Cur_capacity1 uint16
1402 Multsect uint8
1403 Multsect_valid uint8
1404 Lba_capacity uint32
1405 Dma_1word uint16
1406 Dma_mword uint16
1407 Eide_pio_modes uint16
1408 Eide_dma_min uint16
1409 Eide_dma_time uint16
1410 Eide_pio uint16
1411 Eide_pio_iordy uint16
1412 Words69_70 [2]uint16
1413 Words71_74 [4]uint16
1414 Queue_depth uint16
1415 Words76_79 [4]uint16
1416 Major_rev_num uint16
1417 Minor_rev_num uint16
1418 Command_set_1 uint16
1419 Command_set_2 uint16
1420 Cfsse uint16
1421 Cfs_enable_1 uint16
1422 Cfs_enable_2 uint16
1423 Csf_default uint16
1424 Dma_ultra uint16
1425 Trseuc uint16
1426 TrsEuc uint16
1427 CurAPMvalues uint16
1428 Mprc uint16
1429 Hw_config uint16
1430 Acoustic uint16
1431 Msrqs uint16
1432 Sxfert uint16
1433 Sal uint16
1434 Spg uint32
1435 Lba_capacity_2 uint64
1436 Words104_125 [22]uint16
1437 Last_lun uint16
1438 Word127 uint16
1439 Dlf uint16
1440 Csfo uint16
1441 Words130_155 [26]uint16
1442 Word156 uint16
1443 Words157_159 [3]uint16
1444 Cfa_power uint16
1445 Words161_175 [15]uint16
1446 Words176_205 [30]uint16
1447 Words206_254 [49]uint16
1448 Integrity_word uint16
1449}
1450
1451type Statfs_t struct {
1452 Type int64
1453 Bsize int64
1454 Blocks uint64
1455 Bfree uint64
1456 Bavail uint64
1457 Files uint64
1458 Ffree uint64
1459 Fsid Fsid
1460 Namelen int64
1461 Frsize int64
1462 Flags int64
1463 Spare [4]int64
1464}
1465
1466const (
1467 ST_MANDLOCK = 0x40
1468 ST_NOATIME = 0x400
1469 ST_NODEV = 0x4
1470 ST_NODIRATIME = 0x800
1471 ST_NOEXEC = 0x8
1472 ST_NOSUID = 0x2
1473 ST_RDONLY = 0x1
1474 ST_RELATIME = 0x1000
1475 ST_SYNCHRONOUS = 0x10
1476)
1477
1478type TpacketHdr struct {
1479 Status uint64
1480 Len uint32
1481 Snaplen uint32
1482 Mac uint16
1483 Net uint16
1484 Sec uint32
1485 Usec uint32
1486 _ [4]byte
1487}
1488
1489type Tpacket2Hdr struct {
1490 Status uint32
1491 Len uint32
1492 Snaplen uint32
1493 Mac uint16
1494 Net uint16
1495 Sec uint32
1496 Nsec uint32
1497 Vlan_tci uint16
1498 Vlan_tpid uint16
1499 _ [4]uint8
1500}
1501
1502type Tpacket3Hdr struct {
1503 Next_offset uint32
1504 Sec uint32
1505 Nsec uint32
1506 Snaplen uint32
1507 Len uint32
1508 Status uint32
1509 Mac uint16
1510 Net uint16
1511 Hv1 TpacketHdrVariant1
1512 _ [8]uint8
1513}
1514
1515type TpacketHdrVariant1 struct {
1516 Rxhash uint32
1517 Vlan_tci uint32
1518 Vlan_tpid uint16
1519 _ uint16
1520}
1521
1522type TpacketBlockDesc struct {
1523 Version uint32
1524 To_priv uint32
1525 Hdr [40]byte
1526}
1527
Matteo Scandolof9d43412021-01-12 11:11:34 -08001528type TpacketBDTS struct {
1529 Sec uint32
1530 Usec uint32
1531}
1532
1533type TpacketHdrV1 struct {
1534 Block_status uint32
1535 Num_pkts uint32
1536 Offset_to_first_pkt uint32
1537 Blk_len uint32
1538 Seq_num uint64
1539 Ts_first_pkt TpacketBDTS
1540 Ts_last_pkt TpacketBDTS
1541}
1542
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -07001543type TpacketReq struct {
1544 Block_size uint32
1545 Block_nr uint32
1546 Frame_size uint32
1547 Frame_nr uint32
1548}
1549
1550type TpacketReq3 struct {
1551 Block_size uint32
1552 Block_nr uint32
1553 Frame_size uint32
1554 Frame_nr uint32
1555 Retire_blk_tov uint32
1556 Sizeof_priv uint32
1557 Feature_req_word uint32
1558}
1559
1560type TpacketStats struct {
1561 Packets uint32
1562 Drops uint32
1563}
1564
1565type TpacketStatsV3 struct {
1566 Packets uint32
1567 Drops uint32
1568 Freeze_q_cnt uint32
1569}
1570
1571type TpacketAuxdata struct {
1572 Status uint32
1573 Len uint32
1574 Snaplen uint32
1575 Mac uint16
1576 Net uint16
1577 Vlan_tci uint16
1578 Vlan_tpid uint16
1579}
1580
1581const (
1582 TPACKET_V1 = 0x0
1583 TPACKET_V2 = 0x1
1584 TPACKET_V3 = 0x2
1585)
1586
1587const (
1588 SizeofTpacketHdr = 0x20
1589 SizeofTpacket2Hdr = 0x20
1590 SizeofTpacket3Hdr = 0x30
1591
1592 SizeofTpacketStats = 0x8
1593 SizeofTpacketStatsV3 = 0xc
1594)
1595
1596const (
1597 NF_INET_PRE_ROUTING = 0x0
1598 NF_INET_LOCAL_IN = 0x1
1599 NF_INET_FORWARD = 0x2
1600 NF_INET_LOCAL_OUT = 0x3
1601 NF_INET_POST_ROUTING = 0x4
1602 NF_INET_NUMHOOKS = 0x5
1603)
1604
1605const (
1606 NF_NETDEV_INGRESS = 0x0
1607 NF_NETDEV_NUMHOOKS = 0x1
1608)
1609
1610const (
1611 NFPROTO_UNSPEC = 0x0
1612 NFPROTO_INET = 0x1
1613 NFPROTO_IPV4 = 0x2
1614 NFPROTO_ARP = 0x3
1615 NFPROTO_NETDEV = 0x5
1616 NFPROTO_BRIDGE = 0x7
1617 NFPROTO_IPV6 = 0xa
1618 NFPROTO_DECNET = 0xc
1619 NFPROTO_NUMPROTO = 0xd
1620)
1621
1622type Nfgenmsg struct {
1623 Nfgen_family uint8
1624 Version uint8
1625 Res_id uint16
1626}
1627
1628const (
1629 NFNL_BATCH_UNSPEC = 0x0
1630 NFNL_BATCH_GENID = 0x1
1631)
1632
1633const (
1634 NFT_REG_VERDICT = 0x0
1635 NFT_REG_1 = 0x1
1636 NFT_REG_2 = 0x2
1637 NFT_REG_3 = 0x3
1638 NFT_REG_4 = 0x4
1639 NFT_REG32_00 = 0x8
1640 NFT_REG32_01 = 0x9
1641 NFT_REG32_02 = 0xa
1642 NFT_REG32_03 = 0xb
1643 NFT_REG32_04 = 0xc
1644 NFT_REG32_05 = 0xd
1645 NFT_REG32_06 = 0xe
1646 NFT_REG32_07 = 0xf
1647 NFT_REG32_08 = 0x10
1648 NFT_REG32_09 = 0x11
1649 NFT_REG32_10 = 0x12
1650 NFT_REG32_11 = 0x13
1651 NFT_REG32_12 = 0x14
1652 NFT_REG32_13 = 0x15
1653 NFT_REG32_14 = 0x16
1654 NFT_REG32_15 = 0x17
1655 NFT_CONTINUE = -0x1
1656 NFT_BREAK = -0x2
1657 NFT_JUMP = -0x3
1658 NFT_GOTO = -0x4
1659 NFT_RETURN = -0x5
1660 NFT_MSG_NEWTABLE = 0x0
1661 NFT_MSG_GETTABLE = 0x1
1662 NFT_MSG_DELTABLE = 0x2
1663 NFT_MSG_NEWCHAIN = 0x3
1664 NFT_MSG_GETCHAIN = 0x4
1665 NFT_MSG_DELCHAIN = 0x5
1666 NFT_MSG_NEWRULE = 0x6
1667 NFT_MSG_GETRULE = 0x7
1668 NFT_MSG_DELRULE = 0x8
1669 NFT_MSG_NEWSET = 0x9
1670 NFT_MSG_GETSET = 0xa
1671 NFT_MSG_DELSET = 0xb
1672 NFT_MSG_NEWSETELEM = 0xc
1673 NFT_MSG_GETSETELEM = 0xd
1674 NFT_MSG_DELSETELEM = 0xe
1675 NFT_MSG_NEWGEN = 0xf
1676 NFT_MSG_GETGEN = 0x10
1677 NFT_MSG_TRACE = 0x11
1678 NFT_MSG_NEWOBJ = 0x12
1679 NFT_MSG_GETOBJ = 0x13
1680 NFT_MSG_DELOBJ = 0x14
1681 NFT_MSG_GETOBJ_RESET = 0x15
1682 NFT_MSG_MAX = 0x19
1683 NFTA_LIST_UNPEC = 0x0
1684 NFTA_LIST_ELEM = 0x1
1685 NFTA_HOOK_UNSPEC = 0x0
1686 NFTA_HOOK_HOOKNUM = 0x1
1687 NFTA_HOOK_PRIORITY = 0x2
1688 NFTA_HOOK_DEV = 0x3
1689 NFT_TABLE_F_DORMANT = 0x1
1690 NFTA_TABLE_UNSPEC = 0x0
1691 NFTA_TABLE_NAME = 0x1
1692 NFTA_TABLE_FLAGS = 0x2
1693 NFTA_TABLE_USE = 0x3
1694 NFTA_CHAIN_UNSPEC = 0x0
1695 NFTA_CHAIN_TABLE = 0x1
1696 NFTA_CHAIN_HANDLE = 0x2
1697 NFTA_CHAIN_NAME = 0x3
1698 NFTA_CHAIN_HOOK = 0x4
1699 NFTA_CHAIN_POLICY = 0x5
1700 NFTA_CHAIN_USE = 0x6
1701 NFTA_CHAIN_TYPE = 0x7
1702 NFTA_CHAIN_COUNTERS = 0x8
1703 NFTA_CHAIN_PAD = 0x9
1704 NFTA_RULE_UNSPEC = 0x0
1705 NFTA_RULE_TABLE = 0x1
1706 NFTA_RULE_CHAIN = 0x2
1707 NFTA_RULE_HANDLE = 0x3
1708 NFTA_RULE_EXPRESSIONS = 0x4
1709 NFTA_RULE_COMPAT = 0x5
1710 NFTA_RULE_POSITION = 0x6
1711 NFTA_RULE_USERDATA = 0x7
1712 NFTA_RULE_PAD = 0x8
1713 NFTA_RULE_ID = 0x9
1714 NFT_RULE_COMPAT_F_INV = 0x2
1715 NFT_RULE_COMPAT_F_MASK = 0x2
1716 NFTA_RULE_COMPAT_UNSPEC = 0x0
1717 NFTA_RULE_COMPAT_PROTO = 0x1
1718 NFTA_RULE_COMPAT_FLAGS = 0x2
1719 NFT_SET_ANONYMOUS = 0x1
1720 NFT_SET_CONSTANT = 0x2
1721 NFT_SET_INTERVAL = 0x4
1722 NFT_SET_MAP = 0x8
1723 NFT_SET_TIMEOUT = 0x10
1724 NFT_SET_EVAL = 0x20
1725 NFT_SET_OBJECT = 0x40
1726 NFT_SET_POL_PERFORMANCE = 0x0
1727 NFT_SET_POL_MEMORY = 0x1
1728 NFTA_SET_DESC_UNSPEC = 0x0
1729 NFTA_SET_DESC_SIZE = 0x1
1730 NFTA_SET_UNSPEC = 0x0
1731 NFTA_SET_TABLE = 0x1
1732 NFTA_SET_NAME = 0x2
1733 NFTA_SET_FLAGS = 0x3
1734 NFTA_SET_KEY_TYPE = 0x4
1735 NFTA_SET_KEY_LEN = 0x5
1736 NFTA_SET_DATA_TYPE = 0x6
1737 NFTA_SET_DATA_LEN = 0x7
1738 NFTA_SET_POLICY = 0x8
1739 NFTA_SET_DESC = 0x9
1740 NFTA_SET_ID = 0xa
1741 NFTA_SET_TIMEOUT = 0xb
1742 NFTA_SET_GC_INTERVAL = 0xc
1743 NFTA_SET_USERDATA = 0xd
1744 NFTA_SET_PAD = 0xe
1745 NFTA_SET_OBJ_TYPE = 0xf
1746 NFT_SET_ELEM_INTERVAL_END = 0x1
1747 NFTA_SET_ELEM_UNSPEC = 0x0
1748 NFTA_SET_ELEM_KEY = 0x1
1749 NFTA_SET_ELEM_DATA = 0x2
1750 NFTA_SET_ELEM_FLAGS = 0x3
1751 NFTA_SET_ELEM_TIMEOUT = 0x4
1752 NFTA_SET_ELEM_EXPIRATION = 0x5
1753 NFTA_SET_ELEM_USERDATA = 0x6
1754 NFTA_SET_ELEM_EXPR = 0x7
1755 NFTA_SET_ELEM_PAD = 0x8
1756 NFTA_SET_ELEM_OBJREF = 0x9
1757 NFTA_SET_ELEM_LIST_UNSPEC = 0x0
1758 NFTA_SET_ELEM_LIST_TABLE = 0x1
1759 NFTA_SET_ELEM_LIST_SET = 0x2
1760 NFTA_SET_ELEM_LIST_ELEMENTS = 0x3
1761 NFTA_SET_ELEM_LIST_SET_ID = 0x4
1762 NFT_DATA_VALUE = 0x0
1763 NFT_DATA_VERDICT = 0xffffff00
1764 NFTA_DATA_UNSPEC = 0x0
1765 NFTA_DATA_VALUE = 0x1
1766 NFTA_DATA_VERDICT = 0x2
1767 NFTA_VERDICT_UNSPEC = 0x0
1768 NFTA_VERDICT_CODE = 0x1
1769 NFTA_VERDICT_CHAIN = 0x2
1770 NFTA_EXPR_UNSPEC = 0x0
1771 NFTA_EXPR_NAME = 0x1
1772 NFTA_EXPR_DATA = 0x2
1773 NFTA_IMMEDIATE_UNSPEC = 0x0
1774 NFTA_IMMEDIATE_DREG = 0x1
1775 NFTA_IMMEDIATE_DATA = 0x2
1776 NFTA_BITWISE_UNSPEC = 0x0
1777 NFTA_BITWISE_SREG = 0x1
1778 NFTA_BITWISE_DREG = 0x2
1779 NFTA_BITWISE_LEN = 0x3
1780 NFTA_BITWISE_MASK = 0x4
1781 NFTA_BITWISE_XOR = 0x5
1782 NFT_BYTEORDER_NTOH = 0x0
1783 NFT_BYTEORDER_HTON = 0x1
1784 NFTA_BYTEORDER_UNSPEC = 0x0
1785 NFTA_BYTEORDER_SREG = 0x1
1786 NFTA_BYTEORDER_DREG = 0x2
1787 NFTA_BYTEORDER_OP = 0x3
1788 NFTA_BYTEORDER_LEN = 0x4
1789 NFTA_BYTEORDER_SIZE = 0x5
1790 NFT_CMP_EQ = 0x0
1791 NFT_CMP_NEQ = 0x1
1792 NFT_CMP_LT = 0x2
1793 NFT_CMP_LTE = 0x3
1794 NFT_CMP_GT = 0x4
1795 NFT_CMP_GTE = 0x5
1796 NFTA_CMP_UNSPEC = 0x0
1797 NFTA_CMP_SREG = 0x1
1798 NFTA_CMP_OP = 0x2
1799 NFTA_CMP_DATA = 0x3
1800 NFT_RANGE_EQ = 0x0
1801 NFT_RANGE_NEQ = 0x1
1802 NFTA_RANGE_UNSPEC = 0x0
1803 NFTA_RANGE_SREG = 0x1
1804 NFTA_RANGE_OP = 0x2
1805 NFTA_RANGE_FROM_DATA = 0x3
1806 NFTA_RANGE_TO_DATA = 0x4
1807 NFT_LOOKUP_F_INV = 0x1
1808 NFTA_LOOKUP_UNSPEC = 0x0
1809 NFTA_LOOKUP_SET = 0x1
1810 NFTA_LOOKUP_SREG = 0x2
1811 NFTA_LOOKUP_DREG = 0x3
1812 NFTA_LOOKUP_SET_ID = 0x4
1813 NFTA_LOOKUP_FLAGS = 0x5
1814 NFT_DYNSET_OP_ADD = 0x0
1815 NFT_DYNSET_OP_UPDATE = 0x1
1816 NFT_DYNSET_F_INV = 0x1
1817 NFTA_DYNSET_UNSPEC = 0x0
1818 NFTA_DYNSET_SET_NAME = 0x1
1819 NFTA_DYNSET_SET_ID = 0x2
1820 NFTA_DYNSET_OP = 0x3
1821 NFTA_DYNSET_SREG_KEY = 0x4
1822 NFTA_DYNSET_SREG_DATA = 0x5
1823 NFTA_DYNSET_TIMEOUT = 0x6
1824 NFTA_DYNSET_EXPR = 0x7
1825 NFTA_DYNSET_PAD = 0x8
1826 NFTA_DYNSET_FLAGS = 0x9
1827 NFT_PAYLOAD_LL_HEADER = 0x0
1828 NFT_PAYLOAD_NETWORK_HEADER = 0x1
1829 NFT_PAYLOAD_TRANSPORT_HEADER = 0x2
1830 NFT_PAYLOAD_CSUM_NONE = 0x0
1831 NFT_PAYLOAD_CSUM_INET = 0x1
1832 NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1
1833 NFTA_PAYLOAD_UNSPEC = 0x0
1834 NFTA_PAYLOAD_DREG = 0x1
1835 NFTA_PAYLOAD_BASE = 0x2
1836 NFTA_PAYLOAD_OFFSET = 0x3
1837 NFTA_PAYLOAD_LEN = 0x4
1838 NFTA_PAYLOAD_SREG = 0x5
1839 NFTA_PAYLOAD_CSUM_TYPE = 0x6
1840 NFTA_PAYLOAD_CSUM_OFFSET = 0x7
1841 NFTA_PAYLOAD_CSUM_FLAGS = 0x8
1842 NFT_EXTHDR_F_PRESENT = 0x1
1843 NFT_EXTHDR_OP_IPV6 = 0x0
1844 NFT_EXTHDR_OP_TCPOPT = 0x1
1845 NFTA_EXTHDR_UNSPEC = 0x0
1846 NFTA_EXTHDR_DREG = 0x1
1847 NFTA_EXTHDR_TYPE = 0x2
1848 NFTA_EXTHDR_OFFSET = 0x3
1849 NFTA_EXTHDR_LEN = 0x4
1850 NFTA_EXTHDR_FLAGS = 0x5
1851 NFTA_EXTHDR_OP = 0x6
1852 NFTA_EXTHDR_SREG = 0x7
1853 NFT_META_LEN = 0x0
1854 NFT_META_PROTOCOL = 0x1
1855 NFT_META_PRIORITY = 0x2
1856 NFT_META_MARK = 0x3
1857 NFT_META_IIF = 0x4
1858 NFT_META_OIF = 0x5
1859 NFT_META_IIFNAME = 0x6
1860 NFT_META_OIFNAME = 0x7
1861 NFT_META_IIFTYPE = 0x8
1862 NFT_META_OIFTYPE = 0x9
1863 NFT_META_SKUID = 0xa
1864 NFT_META_SKGID = 0xb
1865 NFT_META_NFTRACE = 0xc
1866 NFT_META_RTCLASSID = 0xd
1867 NFT_META_SECMARK = 0xe
1868 NFT_META_NFPROTO = 0xf
1869 NFT_META_L4PROTO = 0x10
1870 NFT_META_BRI_IIFNAME = 0x11
1871 NFT_META_BRI_OIFNAME = 0x12
1872 NFT_META_PKTTYPE = 0x13
1873 NFT_META_CPU = 0x14
1874 NFT_META_IIFGROUP = 0x15
1875 NFT_META_OIFGROUP = 0x16
1876 NFT_META_CGROUP = 0x17
1877 NFT_META_PRANDOM = 0x18
1878 NFT_RT_CLASSID = 0x0
1879 NFT_RT_NEXTHOP4 = 0x1
1880 NFT_RT_NEXTHOP6 = 0x2
1881 NFT_RT_TCPMSS = 0x3
1882 NFT_HASH_JENKINS = 0x0
1883 NFT_HASH_SYM = 0x1
1884 NFTA_HASH_UNSPEC = 0x0
1885 NFTA_HASH_SREG = 0x1
1886 NFTA_HASH_DREG = 0x2
1887 NFTA_HASH_LEN = 0x3
1888 NFTA_HASH_MODULUS = 0x4
1889 NFTA_HASH_SEED = 0x5
1890 NFTA_HASH_OFFSET = 0x6
1891 NFTA_HASH_TYPE = 0x7
1892 NFTA_META_UNSPEC = 0x0
1893 NFTA_META_DREG = 0x1
1894 NFTA_META_KEY = 0x2
1895 NFTA_META_SREG = 0x3
1896 NFTA_RT_UNSPEC = 0x0
1897 NFTA_RT_DREG = 0x1
1898 NFTA_RT_KEY = 0x2
1899 NFT_CT_STATE = 0x0
1900 NFT_CT_DIRECTION = 0x1
1901 NFT_CT_STATUS = 0x2
1902 NFT_CT_MARK = 0x3
1903 NFT_CT_SECMARK = 0x4
1904 NFT_CT_EXPIRATION = 0x5
1905 NFT_CT_HELPER = 0x6
1906 NFT_CT_L3PROTOCOL = 0x7
1907 NFT_CT_SRC = 0x8
1908 NFT_CT_DST = 0x9
1909 NFT_CT_PROTOCOL = 0xa
1910 NFT_CT_PROTO_SRC = 0xb
1911 NFT_CT_PROTO_DST = 0xc
1912 NFT_CT_LABELS = 0xd
1913 NFT_CT_PKTS = 0xe
1914 NFT_CT_BYTES = 0xf
1915 NFT_CT_AVGPKT = 0x10
1916 NFT_CT_ZONE = 0x11
1917 NFT_CT_EVENTMASK = 0x12
1918 NFTA_CT_UNSPEC = 0x0
1919 NFTA_CT_DREG = 0x1
1920 NFTA_CT_KEY = 0x2
1921 NFTA_CT_DIRECTION = 0x3
1922 NFTA_CT_SREG = 0x4
1923 NFT_LIMIT_PKTS = 0x0
1924 NFT_LIMIT_PKT_BYTES = 0x1
1925 NFT_LIMIT_F_INV = 0x1
1926 NFTA_LIMIT_UNSPEC = 0x0
1927 NFTA_LIMIT_RATE = 0x1
1928 NFTA_LIMIT_UNIT = 0x2
1929 NFTA_LIMIT_BURST = 0x3
1930 NFTA_LIMIT_TYPE = 0x4
1931 NFTA_LIMIT_FLAGS = 0x5
1932 NFTA_LIMIT_PAD = 0x6
1933 NFTA_COUNTER_UNSPEC = 0x0
1934 NFTA_COUNTER_BYTES = 0x1
1935 NFTA_COUNTER_PACKETS = 0x2
1936 NFTA_COUNTER_PAD = 0x3
1937 NFTA_LOG_UNSPEC = 0x0
1938 NFTA_LOG_GROUP = 0x1
1939 NFTA_LOG_PREFIX = 0x2
1940 NFTA_LOG_SNAPLEN = 0x3
1941 NFTA_LOG_QTHRESHOLD = 0x4
1942 NFTA_LOG_LEVEL = 0x5
1943 NFTA_LOG_FLAGS = 0x6
1944 NFTA_QUEUE_UNSPEC = 0x0
1945 NFTA_QUEUE_NUM = 0x1
1946 NFTA_QUEUE_TOTAL = 0x2
1947 NFTA_QUEUE_FLAGS = 0x3
1948 NFTA_QUEUE_SREG_QNUM = 0x4
1949 NFT_QUOTA_F_INV = 0x1
1950 NFT_QUOTA_F_DEPLETED = 0x2
1951 NFTA_QUOTA_UNSPEC = 0x0
1952 NFTA_QUOTA_BYTES = 0x1
1953 NFTA_QUOTA_FLAGS = 0x2
1954 NFTA_QUOTA_PAD = 0x3
1955 NFTA_QUOTA_CONSUMED = 0x4
1956 NFT_REJECT_ICMP_UNREACH = 0x0
1957 NFT_REJECT_TCP_RST = 0x1
1958 NFT_REJECT_ICMPX_UNREACH = 0x2
1959 NFT_REJECT_ICMPX_NO_ROUTE = 0x0
1960 NFT_REJECT_ICMPX_PORT_UNREACH = 0x1
1961 NFT_REJECT_ICMPX_HOST_UNREACH = 0x2
1962 NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3
1963 NFTA_REJECT_UNSPEC = 0x0
1964 NFTA_REJECT_TYPE = 0x1
1965 NFTA_REJECT_ICMP_CODE = 0x2
1966 NFT_NAT_SNAT = 0x0
1967 NFT_NAT_DNAT = 0x1
1968 NFTA_NAT_UNSPEC = 0x0
1969 NFTA_NAT_TYPE = 0x1
1970 NFTA_NAT_FAMILY = 0x2
1971 NFTA_NAT_REG_ADDR_MIN = 0x3
1972 NFTA_NAT_REG_ADDR_MAX = 0x4
1973 NFTA_NAT_REG_PROTO_MIN = 0x5
1974 NFTA_NAT_REG_PROTO_MAX = 0x6
1975 NFTA_NAT_FLAGS = 0x7
1976 NFTA_MASQ_UNSPEC = 0x0
1977 NFTA_MASQ_FLAGS = 0x1
1978 NFTA_MASQ_REG_PROTO_MIN = 0x2
1979 NFTA_MASQ_REG_PROTO_MAX = 0x3
1980 NFTA_REDIR_UNSPEC = 0x0
1981 NFTA_REDIR_REG_PROTO_MIN = 0x1
1982 NFTA_REDIR_REG_PROTO_MAX = 0x2
1983 NFTA_REDIR_FLAGS = 0x3
1984 NFTA_DUP_UNSPEC = 0x0
1985 NFTA_DUP_SREG_ADDR = 0x1
1986 NFTA_DUP_SREG_DEV = 0x2
1987 NFTA_FWD_UNSPEC = 0x0
1988 NFTA_FWD_SREG_DEV = 0x1
1989 NFTA_OBJREF_UNSPEC = 0x0
1990 NFTA_OBJREF_IMM_TYPE = 0x1
1991 NFTA_OBJREF_IMM_NAME = 0x2
1992 NFTA_OBJREF_SET_SREG = 0x3
1993 NFTA_OBJREF_SET_NAME = 0x4
1994 NFTA_OBJREF_SET_ID = 0x5
1995 NFTA_GEN_UNSPEC = 0x0
1996 NFTA_GEN_ID = 0x1
1997 NFTA_GEN_PROC_PID = 0x2
1998 NFTA_GEN_PROC_NAME = 0x3
1999 NFTA_FIB_UNSPEC = 0x0
2000 NFTA_FIB_DREG = 0x1
2001 NFTA_FIB_RESULT = 0x2
2002 NFTA_FIB_FLAGS = 0x3
2003 NFT_FIB_RESULT_UNSPEC = 0x0
2004 NFT_FIB_RESULT_OIF = 0x1
2005 NFT_FIB_RESULT_OIFNAME = 0x2
2006 NFT_FIB_RESULT_ADDRTYPE = 0x3
2007 NFTA_FIB_F_SADDR = 0x1
2008 NFTA_FIB_F_DADDR = 0x2
2009 NFTA_FIB_F_MARK = 0x4
2010 NFTA_FIB_F_IIF = 0x8
2011 NFTA_FIB_F_OIF = 0x10
2012 NFTA_FIB_F_PRESENT = 0x20
2013 NFTA_CT_HELPER_UNSPEC = 0x0
2014 NFTA_CT_HELPER_NAME = 0x1
2015 NFTA_CT_HELPER_L3PROTO = 0x2
2016 NFTA_CT_HELPER_L4PROTO = 0x3
2017 NFTA_OBJ_UNSPEC = 0x0
2018 NFTA_OBJ_TABLE = 0x1
2019 NFTA_OBJ_NAME = 0x2
2020 NFTA_OBJ_TYPE = 0x3
2021 NFTA_OBJ_DATA = 0x4
2022 NFTA_OBJ_USE = 0x5
2023 NFTA_TRACE_UNSPEC = 0x0
2024 NFTA_TRACE_TABLE = 0x1
2025 NFTA_TRACE_CHAIN = 0x2
2026 NFTA_TRACE_RULE_HANDLE = 0x3
2027 NFTA_TRACE_TYPE = 0x4
2028 NFTA_TRACE_VERDICT = 0x5
2029 NFTA_TRACE_ID = 0x6
2030 NFTA_TRACE_LL_HEADER = 0x7
2031 NFTA_TRACE_NETWORK_HEADER = 0x8
2032 NFTA_TRACE_TRANSPORT_HEADER = 0x9
2033 NFTA_TRACE_IIF = 0xa
2034 NFTA_TRACE_IIFTYPE = 0xb
2035 NFTA_TRACE_OIF = 0xc
2036 NFTA_TRACE_OIFTYPE = 0xd
2037 NFTA_TRACE_MARK = 0xe
2038 NFTA_TRACE_NFPROTO = 0xf
2039 NFTA_TRACE_POLICY = 0x10
2040 NFTA_TRACE_PAD = 0x11
2041 NFT_TRACETYPE_UNSPEC = 0x0
2042 NFT_TRACETYPE_POLICY = 0x1
2043 NFT_TRACETYPE_RETURN = 0x2
2044 NFT_TRACETYPE_RULE = 0x3
2045 NFTA_NG_UNSPEC = 0x0
2046 NFTA_NG_DREG = 0x1
2047 NFTA_NG_MODULUS = 0x2
2048 NFTA_NG_TYPE = 0x3
2049 NFTA_NG_OFFSET = 0x4
2050 NFT_NG_INCREMENTAL = 0x0
2051 NFT_NG_RANDOM = 0x1
2052)
2053
2054type RTCTime struct {
2055 Sec int32
2056 Min int32
2057 Hour int32
2058 Mday int32
2059 Mon int32
2060 Year int32
2061 Wday int32
2062 Yday int32
2063 Isdst int32
2064}
2065
2066type RTCWkAlrm struct {
2067 Enabled uint8
2068 Pending uint8
2069 Time RTCTime
2070}
2071
2072type RTCPLLInfo struct {
2073 Ctrl int32
2074 Value int32
2075 Max int32
2076 Min int32
2077 Posmult int32
2078 Negmult int32
2079 Clock int64
2080}
2081
2082type BlkpgIoctlArg struct {
2083 Op int32
2084 Flags int32
2085 Datalen int32
2086 Data *byte
2087}
2088
2089type BlkpgPartition struct {
2090 Start int64
2091 Length int64
2092 Pno int32
2093 Devname [64]uint8
2094 Volname [64]uint8
2095 _ [4]byte
2096}
2097
2098const (
2099 BLKPG = 0x1269
2100 BLKPG_ADD_PARTITION = 0x1
2101 BLKPG_DEL_PARTITION = 0x2
2102 BLKPG_RESIZE_PARTITION = 0x3
2103)
2104
2105const (
2106 NETNSA_NONE = 0x0
2107 NETNSA_NSID = 0x1
2108 NETNSA_PID = 0x2
2109 NETNSA_FD = 0x3
2110)
2111
2112type XDPRingOffset struct {
2113 Producer uint64
2114 Consumer uint64
2115 Desc uint64
Matteo Scandolof9d43412021-01-12 11:11:34 -08002116 Flags uint64
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -07002117}
2118
2119type XDPMmapOffsets struct {
2120 Rx XDPRingOffset
2121 Tx XDPRingOffset
2122 Fr XDPRingOffset
2123 Cr XDPRingOffset
2124}
2125
2126type XDPUmemReg struct {
2127 Addr uint64
2128 Len uint64
2129 Size uint32
2130 Headroom uint32
Matteo Scandolof9d43412021-01-12 11:11:34 -08002131 Flags uint32
2132 _ [4]byte
Matteo Scandoloa6a3aee2019-11-26 13:30:14 -07002133}
2134
2135type XDPStatistics struct {
2136 Rx_dropped uint64
2137 Rx_invalid_descs uint64
2138 Tx_invalid_descs uint64
2139}
2140
2141type XDPDesc struct {
2142 Addr uint64
2143 Len uint32
2144 Options uint32
2145}
2146
2147const (
2148 NCSI_CMD_UNSPEC = 0x0
2149 NCSI_CMD_PKG_INFO = 0x1
2150 NCSI_CMD_SET_INTERFACE = 0x2
2151 NCSI_CMD_CLEAR_INTERFACE = 0x3
2152 NCSI_ATTR_UNSPEC = 0x0
2153 NCSI_ATTR_IFINDEX = 0x1
2154 NCSI_ATTR_PACKAGE_LIST = 0x2
2155 NCSI_ATTR_PACKAGE_ID = 0x3
2156 NCSI_ATTR_CHANNEL_ID = 0x4
2157 NCSI_PKG_ATTR_UNSPEC = 0x0
2158 NCSI_PKG_ATTR = 0x1
2159 NCSI_PKG_ATTR_ID = 0x2
2160 NCSI_PKG_ATTR_FORCED = 0x3
2161 NCSI_PKG_ATTR_CHANNEL_LIST = 0x4
2162 NCSI_CHANNEL_ATTR_UNSPEC = 0x0
2163 NCSI_CHANNEL_ATTR = 0x1
2164 NCSI_CHANNEL_ATTR_ID = 0x2
2165 NCSI_CHANNEL_ATTR_VERSION_MAJOR = 0x3
2166 NCSI_CHANNEL_ATTR_VERSION_MINOR = 0x4
2167 NCSI_CHANNEL_ATTR_VERSION_STR = 0x5
2168 NCSI_CHANNEL_ATTR_LINK_STATE = 0x6
2169 NCSI_CHANNEL_ATTR_ACTIVE = 0x7
2170 NCSI_CHANNEL_ATTR_FORCED = 0x8
2171 NCSI_CHANNEL_ATTR_VLAN_LIST = 0x9
2172 NCSI_CHANNEL_ATTR_VLAN_ID = 0xa
2173)
2174
2175type ScmTimestamping struct {
2176 Ts [3]Timespec
2177}
2178
2179const (
2180 SOF_TIMESTAMPING_TX_HARDWARE = 0x1
2181 SOF_TIMESTAMPING_TX_SOFTWARE = 0x2
2182 SOF_TIMESTAMPING_RX_HARDWARE = 0x4
2183 SOF_TIMESTAMPING_RX_SOFTWARE = 0x8
2184 SOF_TIMESTAMPING_SOFTWARE = 0x10
2185 SOF_TIMESTAMPING_SYS_HARDWARE = 0x20
2186 SOF_TIMESTAMPING_RAW_HARDWARE = 0x40
2187 SOF_TIMESTAMPING_OPT_ID = 0x80
2188 SOF_TIMESTAMPING_TX_SCHED = 0x100
2189 SOF_TIMESTAMPING_TX_ACK = 0x200
2190 SOF_TIMESTAMPING_OPT_CMSG = 0x400
2191 SOF_TIMESTAMPING_OPT_TSONLY = 0x800
2192 SOF_TIMESTAMPING_OPT_STATS = 0x1000
2193 SOF_TIMESTAMPING_OPT_PKTINFO = 0x2000
2194 SOF_TIMESTAMPING_OPT_TX_SWHW = 0x4000
2195
2196 SOF_TIMESTAMPING_LAST = 0x4000
2197 SOF_TIMESTAMPING_MASK = 0x7fff
2198
2199 SCM_TSTAMP_SND = 0x0
2200 SCM_TSTAMP_SCHED = 0x1
2201 SCM_TSTAMP_ACK = 0x2
2202)
2203
2204type SockExtendedErr struct {
2205 Errno uint32
2206 Origin uint8
2207 Type uint8
2208 Code uint8
2209 Pad uint8
2210 Info uint32
2211 Data uint32
2212}
2213
2214type FanotifyEventMetadata struct {
2215 Event_len uint32
2216 Vers uint8
2217 Reserved uint8
2218 Metadata_len uint16
2219 Mask uint64
2220 Fd int32
2221 Pid int32
2222}
2223
2224type FanotifyResponse struct {
2225 Fd int32
2226 Response uint32
2227}
Matteo Scandolof9d43412021-01-12 11:11:34 -08002228
2229const (
2230 CRYPTO_MSG_BASE = 0x10
2231 CRYPTO_MSG_NEWALG = 0x10
2232 CRYPTO_MSG_DELALG = 0x11
2233 CRYPTO_MSG_UPDATEALG = 0x12
2234 CRYPTO_MSG_GETALG = 0x13
2235 CRYPTO_MSG_DELRNG = 0x14
2236 CRYPTO_MSG_GETSTAT = 0x15
2237)
2238
2239const (
2240 CRYPTOCFGA_UNSPEC = 0x0
2241 CRYPTOCFGA_PRIORITY_VAL = 0x1
2242 CRYPTOCFGA_REPORT_LARVAL = 0x2
2243 CRYPTOCFGA_REPORT_HASH = 0x3
2244 CRYPTOCFGA_REPORT_BLKCIPHER = 0x4
2245 CRYPTOCFGA_REPORT_AEAD = 0x5
2246 CRYPTOCFGA_REPORT_COMPRESS = 0x6
2247 CRYPTOCFGA_REPORT_RNG = 0x7
2248 CRYPTOCFGA_REPORT_CIPHER = 0x8
2249 CRYPTOCFGA_REPORT_AKCIPHER = 0x9
2250 CRYPTOCFGA_REPORT_KPP = 0xa
2251 CRYPTOCFGA_REPORT_ACOMP = 0xb
2252 CRYPTOCFGA_STAT_LARVAL = 0xc
2253 CRYPTOCFGA_STAT_HASH = 0xd
2254 CRYPTOCFGA_STAT_BLKCIPHER = 0xe
2255 CRYPTOCFGA_STAT_AEAD = 0xf
2256 CRYPTOCFGA_STAT_COMPRESS = 0x10
2257 CRYPTOCFGA_STAT_RNG = 0x11
2258 CRYPTOCFGA_STAT_CIPHER = 0x12
2259 CRYPTOCFGA_STAT_AKCIPHER = 0x13
2260 CRYPTOCFGA_STAT_KPP = 0x14
2261 CRYPTOCFGA_STAT_ACOMP = 0x15
2262)
2263
2264type CryptoUserAlg struct {
2265 Name [64]int8
2266 Driver_name [64]int8
2267 Module_name [64]int8
2268 Type uint32
2269 Mask uint32
2270 Refcnt uint32
2271 Flags uint32
2272}
2273
2274type CryptoStatAEAD struct {
2275 Type [64]int8
2276 Encrypt_cnt uint64
2277 Encrypt_tlen uint64
2278 Decrypt_cnt uint64
2279 Decrypt_tlen uint64
2280 Err_cnt uint64
2281}
2282
2283type CryptoStatAKCipher struct {
2284 Type [64]int8
2285 Encrypt_cnt uint64
2286 Encrypt_tlen uint64
2287 Decrypt_cnt uint64
2288 Decrypt_tlen uint64
2289 Verify_cnt uint64
2290 Sign_cnt uint64
2291 Err_cnt uint64
2292}
2293
2294type CryptoStatCipher struct {
2295 Type [64]int8
2296 Encrypt_cnt uint64
2297 Encrypt_tlen uint64
2298 Decrypt_cnt uint64
2299 Decrypt_tlen uint64
2300 Err_cnt uint64
2301}
2302
2303type CryptoStatCompress struct {
2304 Type [64]int8
2305 Compress_cnt uint64
2306 Compress_tlen uint64
2307 Decompress_cnt uint64
2308 Decompress_tlen uint64
2309 Err_cnt uint64
2310}
2311
2312type CryptoStatHash struct {
2313 Type [64]int8
2314 Hash_cnt uint64
2315 Hash_tlen uint64
2316 Err_cnt uint64
2317}
2318
2319type CryptoStatKPP struct {
2320 Type [64]int8
2321 Setsecret_cnt uint64
2322 Generate_public_key_cnt uint64
2323 Compute_shared_secret_cnt uint64
2324 Err_cnt uint64
2325}
2326
2327type CryptoStatRNG struct {
2328 Type [64]int8
2329 Generate_cnt uint64
2330 Generate_tlen uint64
2331 Seed_cnt uint64
2332 Err_cnt uint64
2333}
2334
2335type CryptoStatLarval struct {
2336 Type [64]int8
2337}
2338
2339type CryptoReportLarval struct {
2340 Type [64]int8
2341}
2342
2343type CryptoReportHash struct {
2344 Type [64]int8
2345 Blocksize uint32
2346 Digestsize uint32
2347}
2348
2349type CryptoReportCipher struct {
2350 Type [64]int8
2351 Blocksize uint32
2352 Min_keysize uint32
2353 Max_keysize uint32
2354}
2355
2356type CryptoReportBlkCipher struct {
2357 Type [64]int8
2358 Geniv [64]int8
2359 Blocksize uint32
2360 Min_keysize uint32
2361 Max_keysize uint32
2362 Ivsize uint32
2363}
2364
2365type CryptoReportAEAD struct {
2366 Type [64]int8
2367 Geniv [64]int8
2368 Blocksize uint32
2369 Maxauthsize uint32
2370 Ivsize uint32
2371}
2372
2373type CryptoReportComp struct {
2374 Type [64]int8
2375}
2376
2377type CryptoReportRNG struct {
2378 Type [64]int8
2379 Seedsize uint32
2380}
2381
2382type CryptoReportAKCipher struct {
2383 Type [64]int8
2384}
2385
2386type CryptoReportKPP struct {
2387 Type [64]int8
2388}
2389
2390type CryptoReportAcomp struct {
2391 Type [64]int8
2392}
2393
2394const (
2395 BPF_REG_0 = 0x0
2396 BPF_REG_1 = 0x1
2397 BPF_REG_2 = 0x2
2398 BPF_REG_3 = 0x3
2399 BPF_REG_4 = 0x4
2400 BPF_REG_5 = 0x5
2401 BPF_REG_6 = 0x6
2402 BPF_REG_7 = 0x7
2403 BPF_REG_8 = 0x8
2404 BPF_REG_9 = 0x9
2405 BPF_REG_10 = 0xa
2406 BPF_MAP_CREATE = 0x0
2407 BPF_MAP_LOOKUP_ELEM = 0x1
2408 BPF_MAP_UPDATE_ELEM = 0x2
2409 BPF_MAP_DELETE_ELEM = 0x3
2410 BPF_MAP_GET_NEXT_KEY = 0x4
2411 BPF_PROG_LOAD = 0x5
2412 BPF_OBJ_PIN = 0x6
2413 BPF_OBJ_GET = 0x7
2414 BPF_PROG_ATTACH = 0x8
2415 BPF_PROG_DETACH = 0x9
2416 BPF_PROG_TEST_RUN = 0xa
2417 BPF_PROG_GET_NEXT_ID = 0xb
2418 BPF_MAP_GET_NEXT_ID = 0xc
2419 BPF_PROG_GET_FD_BY_ID = 0xd
2420 BPF_MAP_GET_FD_BY_ID = 0xe
2421 BPF_OBJ_GET_INFO_BY_FD = 0xf
2422 BPF_PROG_QUERY = 0x10
2423 BPF_RAW_TRACEPOINT_OPEN = 0x11
2424 BPF_BTF_LOAD = 0x12
2425 BPF_BTF_GET_FD_BY_ID = 0x13
2426 BPF_TASK_FD_QUERY = 0x14
2427 BPF_MAP_LOOKUP_AND_DELETE_ELEM = 0x15
2428 BPF_MAP_TYPE_UNSPEC = 0x0
2429 BPF_MAP_TYPE_HASH = 0x1
2430 BPF_MAP_TYPE_ARRAY = 0x2
2431 BPF_MAP_TYPE_PROG_ARRAY = 0x3
2432 BPF_MAP_TYPE_PERF_EVENT_ARRAY = 0x4
2433 BPF_MAP_TYPE_PERCPU_HASH = 0x5
2434 BPF_MAP_TYPE_PERCPU_ARRAY = 0x6
2435 BPF_MAP_TYPE_STACK_TRACE = 0x7
2436 BPF_MAP_TYPE_CGROUP_ARRAY = 0x8
2437 BPF_MAP_TYPE_LRU_HASH = 0x9
2438 BPF_MAP_TYPE_LRU_PERCPU_HASH = 0xa
2439 BPF_MAP_TYPE_LPM_TRIE = 0xb
2440 BPF_MAP_TYPE_ARRAY_OF_MAPS = 0xc
2441 BPF_MAP_TYPE_HASH_OF_MAPS = 0xd
2442 BPF_MAP_TYPE_DEVMAP = 0xe
2443 BPF_MAP_TYPE_SOCKMAP = 0xf
2444 BPF_MAP_TYPE_CPUMAP = 0x10
2445 BPF_MAP_TYPE_XSKMAP = 0x11
2446 BPF_MAP_TYPE_SOCKHASH = 0x12
2447 BPF_MAP_TYPE_CGROUP_STORAGE = 0x13
2448 BPF_MAP_TYPE_REUSEPORT_SOCKARRAY = 0x14
2449 BPF_MAP_TYPE_PERCPU_CGROUP_STORAGE = 0x15
2450 BPF_MAP_TYPE_QUEUE = 0x16
2451 BPF_MAP_TYPE_STACK = 0x17
2452 BPF_PROG_TYPE_UNSPEC = 0x0
2453 BPF_PROG_TYPE_SOCKET_FILTER = 0x1
2454 BPF_PROG_TYPE_KPROBE = 0x2
2455 BPF_PROG_TYPE_SCHED_CLS = 0x3
2456 BPF_PROG_TYPE_SCHED_ACT = 0x4
2457 BPF_PROG_TYPE_TRACEPOINT = 0x5
2458 BPF_PROG_TYPE_XDP = 0x6
2459 BPF_PROG_TYPE_PERF_EVENT = 0x7
2460 BPF_PROG_TYPE_CGROUP_SKB = 0x8
2461 BPF_PROG_TYPE_CGROUP_SOCK = 0x9
2462 BPF_PROG_TYPE_LWT_IN = 0xa
2463 BPF_PROG_TYPE_LWT_OUT = 0xb
2464 BPF_PROG_TYPE_LWT_XMIT = 0xc
2465 BPF_PROG_TYPE_SOCK_OPS = 0xd
2466 BPF_PROG_TYPE_SK_SKB = 0xe
2467 BPF_PROG_TYPE_CGROUP_DEVICE = 0xf
2468 BPF_PROG_TYPE_SK_MSG = 0x10
2469 BPF_PROG_TYPE_RAW_TRACEPOINT = 0x11
2470 BPF_PROG_TYPE_CGROUP_SOCK_ADDR = 0x12
2471 BPF_PROG_TYPE_LWT_SEG6LOCAL = 0x13
2472 BPF_PROG_TYPE_LIRC_MODE2 = 0x14
2473 BPF_PROG_TYPE_SK_REUSEPORT = 0x15
2474 BPF_PROG_TYPE_FLOW_DISSECTOR = 0x16
2475 BPF_CGROUP_INET_INGRESS = 0x0
2476 BPF_CGROUP_INET_EGRESS = 0x1
2477 BPF_CGROUP_INET_SOCK_CREATE = 0x2
2478 BPF_CGROUP_SOCK_OPS = 0x3
2479 BPF_SK_SKB_STREAM_PARSER = 0x4
2480 BPF_SK_SKB_STREAM_VERDICT = 0x5
2481 BPF_CGROUP_DEVICE = 0x6
2482 BPF_SK_MSG_VERDICT = 0x7
2483 BPF_CGROUP_INET4_BIND = 0x8
2484 BPF_CGROUP_INET6_BIND = 0x9
2485 BPF_CGROUP_INET4_CONNECT = 0xa
2486 BPF_CGROUP_INET6_CONNECT = 0xb
2487 BPF_CGROUP_INET4_POST_BIND = 0xc
2488 BPF_CGROUP_INET6_POST_BIND = 0xd
2489 BPF_CGROUP_UDP4_SENDMSG = 0xe
2490 BPF_CGROUP_UDP6_SENDMSG = 0xf
2491 BPF_LIRC_MODE2 = 0x10
2492 BPF_FLOW_DISSECTOR = 0x11
2493 BPF_STACK_BUILD_ID_EMPTY = 0x0
2494 BPF_STACK_BUILD_ID_VALID = 0x1
2495 BPF_STACK_BUILD_ID_IP = 0x2
2496 BPF_ADJ_ROOM_NET = 0x0
2497 BPF_HDR_START_MAC = 0x0
2498 BPF_HDR_START_NET = 0x1
2499 BPF_LWT_ENCAP_SEG6 = 0x0
2500 BPF_LWT_ENCAP_SEG6_INLINE = 0x1
2501 BPF_OK = 0x0
2502 BPF_DROP = 0x2
2503 BPF_REDIRECT = 0x7
2504 BPF_SOCK_OPS_VOID = 0x0
2505 BPF_SOCK_OPS_TIMEOUT_INIT = 0x1
2506 BPF_SOCK_OPS_RWND_INIT = 0x2
2507 BPF_SOCK_OPS_TCP_CONNECT_CB = 0x3
2508 BPF_SOCK_OPS_ACTIVE_ESTABLISHED_CB = 0x4
2509 BPF_SOCK_OPS_PASSIVE_ESTABLISHED_CB = 0x5
2510 BPF_SOCK_OPS_NEEDS_ECN = 0x6
2511 BPF_SOCK_OPS_BASE_RTT = 0x7
2512 BPF_SOCK_OPS_RTO_CB = 0x8
2513 BPF_SOCK_OPS_RETRANS_CB = 0x9
2514 BPF_SOCK_OPS_STATE_CB = 0xa
2515 BPF_SOCK_OPS_TCP_LISTEN_CB = 0xb
2516 BPF_TCP_ESTABLISHED = 0x1
2517 BPF_TCP_SYN_SENT = 0x2
2518 BPF_TCP_SYN_RECV = 0x3
2519 BPF_TCP_FIN_WAIT1 = 0x4
2520 BPF_TCP_FIN_WAIT2 = 0x5
2521 BPF_TCP_TIME_WAIT = 0x6
2522 BPF_TCP_CLOSE = 0x7
2523 BPF_TCP_CLOSE_WAIT = 0x8
2524 BPF_TCP_LAST_ACK = 0x9
2525 BPF_TCP_LISTEN = 0xa
2526 BPF_TCP_CLOSING = 0xb
2527 BPF_TCP_NEW_SYN_RECV = 0xc
2528 BPF_TCP_MAX_STATES = 0xd
2529 BPF_FIB_LKUP_RET_SUCCESS = 0x0
2530 BPF_FIB_LKUP_RET_BLACKHOLE = 0x1
2531 BPF_FIB_LKUP_RET_UNREACHABLE = 0x2
2532 BPF_FIB_LKUP_RET_PROHIBIT = 0x3
2533 BPF_FIB_LKUP_RET_NOT_FWDED = 0x4
2534 BPF_FIB_LKUP_RET_FWD_DISABLED = 0x5
2535 BPF_FIB_LKUP_RET_UNSUPP_LWT = 0x6
2536 BPF_FIB_LKUP_RET_NO_NEIGH = 0x7
2537 BPF_FIB_LKUP_RET_FRAG_NEEDED = 0x8
2538 BPF_FD_TYPE_RAW_TRACEPOINT = 0x0
2539 BPF_FD_TYPE_TRACEPOINT = 0x1
2540 BPF_FD_TYPE_KPROBE = 0x2
2541 BPF_FD_TYPE_KRETPROBE = 0x3
2542 BPF_FD_TYPE_UPROBE = 0x4
2543 BPF_FD_TYPE_URETPROBE = 0x5
2544)
2545
2546const (
2547 RTNLGRP_NONE = 0x0
2548 RTNLGRP_LINK = 0x1
2549 RTNLGRP_NOTIFY = 0x2
2550 RTNLGRP_NEIGH = 0x3
2551 RTNLGRP_TC = 0x4
2552 RTNLGRP_IPV4_IFADDR = 0x5
2553 RTNLGRP_IPV4_MROUTE = 0x6
2554 RTNLGRP_IPV4_ROUTE = 0x7
2555 RTNLGRP_IPV4_RULE = 0x8
2556 RTNLGRP_IPV6_IFADDR = 0x9
2557 RTNLGRP_IPV6_MROUTE = 0xa
2558 RTNLGRP_IPV6_ROUTE = 0xb
2559 RTNLGRP_IPV6_IFINFO = 0xc
2560 RTNLGRP_DECnet_IFADDR = 0xd
2561 RTNLGRP_NOP2 = 0xe
2562 RTNLGRP_DECnet_ROUTE = 0xf
2563 RTNLGRP_DECnet_RULE = 0x10
2564 RTNLGRP_NOP4 = 0x11
2565 RTNLGRP_IPV6_PREFIX = 0x12
2566 RTNLGRP_IPV6_RULE = 0x13
2567 RTNLGRP_ND_USEROPT = 0x14
2568 RTNLGRP_PHONET_IFADDR = 0x15
2569 RTNLGRP_PHONET_ROUTE = 0x16
2570 RTNLGRP_DCB = 0x17
2571 RTNLGRP_IPV4_NETCONF = 0x18
2572 RTNLGRP_IPV6_NETCONF = 0x19
2573 RTNLGRP_MDB = 0x1a
2574 RTNLGRP_MPLS_ROUTE = 0x1b
2575 RTNLGRP_NSID = 0x1c
2576 RTNLGRP_MPLS_NETCONF = 0x1d
2577 RTNLGRP_IPV4_MROUTE_R = 0x1e
2578 RTNLGRP_IPV6_MROUTE_R = 0x1f
2579 RTNLGRP_NEXTHOP = 0x20
2580)
2581
2582type CapUserHeader struct {
2583 Version uint32
2584 Pid int32
2585}
2586
2587type CapUserData struct {
2588 Effective uint32
2589 Permitted uint32
2590 Inheritable uint32
2591}
2592
2593const (
2594 LINUX_CAPABILITY_VERSION_1 = 0x19980330
2595 LINUX_CAPABILITY_VERSION_2 = 0x20071026
2596 LINUX_CAPABILITY_VERSION_3 = 0x20080522
2597)
2598
2599const (
2600 LO_FLAGS_READ_ONLY = 0x1
2601 LO_FLAGS_AUTOCLEAR = 0x4
2602 LO_FLAGS_PARTSCAN = 0x8
2603 LO_FLAGS_DIRECT_IO = 0x10
2604)
2605
2606type LoopInfo struct {
2607 Number int32
2608 Device uint64
2609 Inode uint64
2610 Rdevice uint64
2611 Offset int32
2612 Encrypt_type int32
2613 Encrypt_key_size int32
2614 Flags int32
2615 Name [64]int8
2616 Encrypt_key [32]uint8
2617 Init [2]uint64
2618 Reserved [4]int8
2619 _ [4]byte
2620}
2621type LoopInfo64 struct {
2622 Device uint64
2623 Inode uint64
2624 Rdevice uint64
2625 Offset uint64
2626 Sizelimit uint64
2627 Number uint32
2628 Encrypt_type uint32
2629 Encrypt_key_size uint32
2630 Flags uint32
2631 File_name [64]uint8
2632 Crypt_name [64]uint8
2633 Encrypt_key [32]uint8
2634 Init [2]uint64
2635}
2636
2637type TIPCSocketAddr struct {
2638 Ref uint32
2639 Node uint32
2640}
2641
2642type TIPCServiceRange struct {
2643 Type uint32
2644 Lower uint32
2645 Upper uint32
2646}
2647
2648type TIPCServiceName struct {
2649 Type uint32
2650 Instance uint32
2651 Domain uint32
2652}
2653
2654type TIPCSubscr struct {
2655 Seq TIPCServiceRange
2656 Timeout uint32
2657 Filter uint32
2658 Handle [8]int8
2659}
2660
2661type TIPCEvent struct {
2662 Event uint32
2663 Lower uint32
2664 Upper uint32
2665 Port TIPCSocketAddr
2666 S TIPCSubscr
2667}
2668
2669type TIPCGroupReq struct {
2670 Type uint32
2671 Instance uint32
2672 Scope uint32
2673 Flags uint32
2674}
2675
2676type TIPCSIOCLNReq struct {
2677 Peer uint32
2678 Id uint32
2679 Linkname [68]int8
2680}
2681
2682type TIPCSIOCNodeIDReq struct {
2683 Peer uint32
2684 Id [16]int8
2685}
2686
2687const (
2688 TIPC_CLUSTER_SCOPE = 0x2
2689 TIPC_NODE_SCOPE = 0x3
2690)
2691
2692const (
2693 SYSLOG_ACTION_CLOSE = 0
2694 SYSLOG_ACTION_OPEN = 1
2695 SYSLOG_ACTION_READ = 2
2696 SYSLOG_ACTION_READ_ALL = 3
2697 SYSLOG_ACTION_READ_CLEAR = 4
2698 SYSLOG_ACTION_CLEAR = 5
2699 SYSLOG_ACTION_CONSOLE_OFF = 6
2700 SYSLOG_ACTION_CONSOLE_ON = 7
2701 SYSLOG_ACTION_CONSOLE_LEVEL = 8
2702 SYSLOG_ACTION_SIZE_UNREAD = 9
2703 SYSLOG_ACTION_SIZE_BUFFER = 10
2704)
2705
2706const (
2707 DEVLINK_CMD_UNSPEC = 0x0
2708 DEVLINK_CMD_GET = 0x1
2709 DEVLINK_CMD_SET = 0x2
2710 DEVLINK_CMD_NEW = 0x3
2711 DEVLINK_CMD_DEL = 0x4
2712 DEVLINK_CMD_PORT_GET = 0x5
2713 DEVLINK_CMD_PORT_SET = 0x6
2714 DEVLINK_CMD_PORT_NEW = 0x7
2715 DEVLINK_CMD_PORT_DEL = 0x8
2716 DEVLINK_CMD_PORT_SPLIT = 0x9
2717 DEVLINK_CMD_PORT_UNSPLIT = 0xa
2718 DEVLINK_CMD_SB_GET = 0xb
2719 DEVLINK_CMD_SB_SET = 0xc
2720 DEVLINK_CMD_SB_NEW = 0xd
2721 DEVLINK_CMD_SB_DEL = 0xe
2722 DEVLINK_CMD_SB_POOL_GET = 0xf
2723 DEVLINK_CMD_SB_POOL_SET = 0x10
2724 DEVLINK_CMD_SB_POOL_NEW = 0x11
2725 DEVLINK_CMD_SB_POOL_DEL = 0x12
2726 DEVLINK_CMD_SB_PORT_POOL_GET = 0x13
2727 DEVLINK_CMD_SB_PORT_POOL_SET = 0x14
2728 DEVLINK_CMD_SB_PORT_POOL_NEW = 0x15
2729 DEVLINK_CMD_SB_PORT_POOL_DEL = 0x16
2730 DEVLINK_CMD_SB_TC_POOL_BIND_GET = 0x17
2731 DEVLINK_CMD_SB_TC_POOL_BIND_SET = 0x18
2732 DEVLINK_CMD_SB_TC_POOL_BIND_NEW = 0x19
2733 DEVLINK_CMD_SB_TC_POOL_BIND_DEL = 0x1a
2734 DEVLINK_CMD_SB_OCC_SNAPSHOT = 0x1b
2735 DEVLINK_CMD_SB_OCC_MAX_CLEAR = 0x1c
2736 DEVLINK_CMD_ESWITCH_GET = 0x1d
2737 DEVLINK_CMD_ESWITCH_SET = 0x1e
2738 DEVLINK_CMD_DPIPE_TABLE_GET = 0x1f
2739 DEVLINK_CMD_DPIPE_ENTRIES_GET = 0x20
2740 DEVLINK_CMD_DPIPE_HEADERS_GET = 0x21
2741 DEVLINK_CMD_DPIPE_TABLE_COUNTERS_SET = 0x22
2742 DEVLINK_CMD_MAX = 0x44
2743 DEVLINK_PORT_TYPE_NOTSET = 0x0
2744 DEVLINK_PORT_TYPE_AUTO = 0x1
2745 DEVLINK_PORT_TYPE_ETH = 0x2
2746 DEVLINK_PORT_TYPE_IB = 0x3
2747 DEVLINK_SB_POOL_TYPE_INGRESS = 0x0
2748 DEVLINK_SB_POOL_TYPE_EGRESS = 0x1
2749 DEVLINK_SB_THRESHOLD_TYPE_STATIC = 0x0
2750 DEVLINK_SB_THRESHOLD_TYPE_DYNAMIC = 0x1
2751 DEVLINK_ESWITCH_MODE_LEGACY = 0x0
2752 DEVLINK_ESWITCH_MODE_SWITCHDEV = 0x1
2753 DEVLINK_ESWITCH_INLINE_MODE_NONE = 0x0
2754 DEVLINK_ESWITCH_INLINE_MODE_LINK = 0x1
2755 DEVLINK_ESWITCH_INLINE_MODE_NETWORK = 0x2
2756 DEVLINK_ESWITCH_INLINE_MODE_TRANSPORT = 0x3
2757 DEVLINK_ESWITCH_ENCAP_MODE_NONE = 0x0
2758 DEVLINK_ESWITCH_ENCAP_MODE_BASIC = 0x1
2759 DEVLINK_ATTR_UNSPEC = 0x0
2760 DEVLINK_ATTR_BUS_NAME = 0x1
2761 DEVLINK_ATTR_DEV_NAME = 0x2
2762 DEVLINK_ATTR_PORT_INDEX = 0x3
2763 DEVLINK_ATTR_PORT_TYPE = 0x4
2764 DEVLINK_ATTR_PORT_DESIRED_TYPE = 0x5
2765 DEVLINK_ATTR_PORT_NETDEV_IFINDEX = 0x6
2766 DEVLINK_ATTR_PORT_NETDEV_NAME = 0x7
2767 DEVLINK_ATTR_PORT_IBDEV_NAME = 0x8
2768 DEVLINK_ATTR_PORT_SPLIT_COUNT = 0x9
2769 DEVLINK_ATTR_PORT_SPLIT_GROUP = 0xa
2770 DEVLINK_ATTR_SB_INDEX = 0xb
2771 DEVLINK_ATTR_SB_SIZE = 0xc
2772 DEVLINK_ATTR_SB_INGRESS_POOL_COUNT = 0xd
2773 DEVLINK_ATTR_SB_EGRESS_POOL_COUNT = 0xe
2774 DEVLINK_ATTR_SB_INGRESS_TC_COUNT = 0xf
2775 DEVLINK_ATTR_SB_EGRESS_TC_COUNT = 0x10
2776 DEVLINK_ATTR_SB_POOL_INDEX = 0x11
2777 DEVLINK_ATTR_SB_POOL_TYPE = 0x12
2778 DEVLINK_ATTR_SB_POOL_SIZE = 0x13
2779 DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE = 0x14
2780 DEVLINK_ATTR_SB_THRESHOLD = 0x15
2781 DEVLINK_ATTR_SB_TC_INDEX = 0x16
2782 DEVLINK_ATTR_SB_OCC_CUR = 0x17
2783 DEVLINK_ATTR_SB_OCC_MAX = 0x18
2784 DEVLINK_ATTR_ESWITCH_MODE = 0x19
2785 DEVLINK_ATTR_ESWITCH_INLINE_MODE = 0x1a
2786 DEVLINK_ATTR_DPIPE_TABLES = 0x1b
2787 DEVLINK_ATTR_DPIPE_TABLE = 0x1c
2788 DEVLINK_ATTR_DPIPE_TABLE_NAME = 0x1d
2789 DEVLINK_ATTR_DPIPE_TABLE_SIZE = 0x1e
2790 DEVLINK_ATTR_DPIPE_TABLE_MATCHES = 0x1f
2791 DEVLINK_ATTR_DPIPE_TABLE_ACTIONS = 0x20
2792 DEVLINK_ATTR_DPIPE_TABLE_COUNTERS_ENABLED = 0x21
2793 DEVLINK_ATTR_DPIPE_ENTRIES = 0x22
2794 DEVLINK_ATTR_DPIPE_ENTRY = 0x23
2795 DEVLINK_ATTR_DPIPE_ENTRY_INDEX = 0x24
2796 DEVLINK_ATTR_DPIPE_ENTRY_MATCH_VALUES = 0x25
2797 DEVLINK_ATTR_DPIPE_ENTRY_ACTION_VALUES = 0x26
2798 DEVLINK_ATTR_DPIPE_ENTRY_COUNTER = 0x27
2799 DEVLINK_ATTR_DPIPE_MATCH = 0x28
2800 DEVLINK_ATTR_DPIPE_MATCH_VALUE = 0x29
2801 DEVLINK_ATTR_DPIPE_MATCH_TYPE = 0x2a
2802 DEVLINK_ATTR_DPIPE_ACTION = 0x2b
2803 DEVLINK_ATTR_DPIPE_ACTION_VALUE = 0x2c
2804 DEVLINK_ATTR_DPIPE_ACTION_TYPE = 0x2d
2805 DEVLINK_ATTR_DPIPE_VALUE = 0x2e
2806 DEVLINK_ATTR_DPIPE_VALUE_MASK = 0x2f
2807 DEVLINK_ATTR_DPIPE_VALUE_MAPPING = 0x30
2808 DEVLINK_ATTR_DPIPE_HEADERS = 0x31
2809 DEVLINK_ATTR_DPIPE_HEADER = 0x32
2810 DEVLINK_ATTR_DPIPE_HEADER_NAME = 0x33
2811 DEVLINK_ATTR_DPIPE_HEADER_ID = 0x34
2812 DEVLINK_ATTR_DPIPE_HEADER_FIELDS = 0x35
2813 DEVLINK_ATTR_DPIPE_HEADER_GLOBAL = 0x36
2814 DEVLINK_ATTR_DPIPE_HEADER_INDEX = 0x37
2815 DEVLINK_ATTR_DPIPE_FIELD = 0x38
2816 DEVLINK_ATTR_DPIPE_FIELD_NAME = 0x39
2817 DEVLINK_ATTR_DPIPE_FIELD_ID = 0x3a
2818 DEVLINK_ATTR_DPIPE_FIELD_BITWIDTH = 0x3b
2819 DEVLINK_ATTR_DPIPE_FIELD_MAPPING_TYPE = 0x3c
2820 DEVLINK_ATTR_PAD = 0x3d
2821 DEVLINK_ATTR_ESWITCH_ENCAP_MODE = 0x3e
2822 DEVLINK_ATTR_MAX = 0x8c
2823 DEVLINK_DPIPE_FIELD_MAPPING_TYPE_NONE = 0x0
2824 DEVLINK_DPIPE_FIELD_MAPPING_TYPE_IFINDEX = 0x1
2825 DEVLINK_DPIPE_MATCH_TYPE_FIELD_EXACT = 0x0
2826 DEVLINK_DPIPE_ACTION_TYPE_FIELD_MODIFY = 0x0
2827 DEVLINK_DPIPE_FIELD_ETHERNET_DST_MAC = 0x0
2828 DEVLINK_DPIPE_FIELD_IPV4_DST_IP = 0x0
2829 DEVLINK_DPIPE_FIELD_IPV6_DST_IP = 0x0
2830 DEVLINK_DPIPE_HEADER_ETHERNET = 0x0
2831 DEVLINK_DPIPE_HEADER_IPV4 = 0x1
2832 DEVLINK_DPIPE_HEADER_IPV6 = 0x2
2833)