| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 1 | /**************************************************************************** | 
|  | 2 | **************************************************************************** | 
|  | 3 | *** | 
|  | 4 | ***   This header was automatically generated from a Linux kernel header | 
|  | 5 | ***   of the same name, to make information necessary for userspace to | 
|  | 6 | ***   call into the kernel available to libc.  It contains only constants, | 
|  | 7 | ***   structures, and macros generated from the original header, and thus, | 
|  | 8 | ***   contains no copyrightable information. | 
|  | 9 | *** | 
|  | 10 | ***   To edit the content of this header, modify the corresponding | 
|  | 11 | ***   source file (e.g. under external/kernel-headers/original/) then | 
|  | 12 | ***   run bionic/libc/kernel/tools/update_all.py | 
|  | 13 | *** | 
|  | 14 | ***   Any manual change here will be lost the next time this script will | 
|  | 15 | ***   be run. You've been warned! | 
|  | 16 | *** | 
|  | 17 | **************************************************************************** | 
|  | 18 | ****************************************************************************/ | 
|  | 19 | #ifndef __LINUX_IF_PACKET_H | 
|  | 20 | #define __LINUX_IF_PACKET_H | 
| Christopher Ferris | 05667cd | 2021-02-16 16:01:34 -0800 | [diff] [blame] | 21 | #include <asm/byteorder.h> | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 22 | #include <linux/types.h> | 
|  | 23 | struct sockaddr_pkt { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 24 | unsigned short spkt_family; | 
|  | 25 | unsigned char spkt_device[14]; | 
|  | 26 | __be16 spkt_protocol; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 27 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 28 | struct sockaddr_ll { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 29 | unsigned short sll_family; | 
|  | 30 | __be16 sll_protocol; | 
|  | 31 | int sll_ifindex; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 32 | unsigned short sll_hatype; | 
|  | 33 | unsigned char sll_pkttype; | 
|  | 34 | unsigned char sll_halen; | 
|  | 35 | unsigned char sll_addr[8]; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 36 | }; | 
|  | 37 | #define PACKET_HOST 0 | 
|  | 38 | #define PACKET_BROADCAST 1 | 
|  | 39 | #define PACKET_MULTICAST 2 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 40 | #define PACKET_OTHERHOST 3 | 
|  | 41 | #define PACKET_OUTGOING 4 | 
|  | 42 | #define PACKET_LOOPBACK 5 | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 43 | #define PACKET_USER 6 | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 44 | #define PACKET_KERNEL 7 | 
|  | 45 | #define PACKET_FASTROUTE 6 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 46 | #define PACKET_ADD_MEMBERSHIP 1 | 
|  | 47 | #define PACKET_DROP_MEMBERSHIP 2 | 
|  | 48 | #define PACKET_RECV_OUTPUT 3 | 
|  | 49 | #define PACKET_RX_RING 5 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 50 | #define PACKET_STATISTICS 6 | 
|  | 51 | #define PACKET_COPY_THRESH 7 | 
|  | 52 | #define PACKET_AUXDATA 8 | 
|  | 53 | #define PACKET_ORIGDEV 9 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 54 | #define PACKET_VERSION 10 | 
|  | 55 | #define PACKET_HDRLEN 11 | 
|  | 56 | #define PACKET_RESERVE 12 | 
|  | 57 | #define PACKET_TX_RING 13 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 58 | #define PACKET_LOSS 14 | 
|  | 59 | #define PACKET_VNET_HDR 15 | 
|  | 60 | #define PACKET_TX_TIMESTAMP 16 | 
|  | 61 | #define PACKET_TIMESTAMP 17 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 62 | #define PACKET_FANOUT 18 | 
|  | 63 | #define PACKET_TX_HAS_OFF 19 | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 64 | #define PACKET_QDISC_BYPASS 20 | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 65 | #define PACKET_ROLLOVER_STATS 21 | 
|  | 66 | #define PACKET_FANOUT_DATA 22 | 
| Christopher Ferris | 86a4837 | 2019-01-10 14:14:59 -0800 | [diff] [blame] | 67 | #define PACKET_IGNORE_OUTGOING 23 | 
| Christopher Ferris | 37c3f3c | 2023-07-10 10:59:05 -0700 | [diff] [blame] | 68 | #define PACKET_VNET_HDR_SZ 24 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 69 | #define PACKET_FANOUT_HASH 0 | 
|  | 70 | #define PACKET_FANOUT_LB 1 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 71 | #define PACKET_FANOUT_CPU 2 | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 72 | #define PACKET_FANOUT_ROLLOVER 3 | 
|  | 73 | #define PACKET_FANOUT_RND 4 | 
|  | 74 | #define PACKET_FANOUT_QM 5 | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 75 | #define PACKET_FANOUT_CBPF 6 | 
|  | 76 | #define PACKET_FANOUT_EBPF 7 | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 77 | #define PACKET_FANOUT_FLAG_ROLLOVER 0x1000 | 
| Christopher Ferris | 525ce91 | 2017-07-26 13:12:53 -0700 | [diff] [blame] | 78 | #define PACKET_FANOUT_FLAG_UNIQUEID 0x2000 | 
| Christopher Ferris | 8b7fdc9 | 2023-02-21 13:36:32 -0800 | [diff] [blame] | 79 | #define PACKET_FANOUT_FLAG_IGNORE_OUTGOING 0x4000 | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 80 | #define PACKET_FANOUT_FLAG_DEFRAG 0x8000 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 81 | struct tpacket_stats { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 82 | unsigned int tp_packets; | 
|  | 83 | unsigned int tp_drops; | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 84 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 85 | struct tpacket_stats_v3 { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 86 | unsigned int tp_packets; | 
|  | 87 | unsigned int tp_drops; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 88 | unsigned int tp_freeze_q_cnt; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 89 | }; | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 90 | struct tpacket_rollover_stats { | 
|  | 91 | __aligned_u64 tp_all; | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 92 | __aligned_u64 tp_huge; | 
|  | 93 | __aligned_u64 tp_failed; | 
|  | 94 | }; | 
|  | 95 | union tpacket_stats_u { | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 96 | struct tpacket_stats stats1; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 97 | struct tpacket_stats_v3 stats3; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 98 | }; | 
|  | 99 | struct tpacket_auxdata { | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 100 | __u32 tp_status; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 101 | __u32 tp_len; | 
|  | 102 | __u32 tp_snaplen; | 
|  | 103 | __u16 tp_mac; | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 104 | __u16 tp_net; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 105 | __u16 tp_vlan_tci; | 
|  | 106 | __u16 tp_vlan_tpid; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 107 | }; | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 108 | #define TP_STATUS_KERNEL 0 | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 109 | #define TP_STATUS_USER (1 << 0) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 110 | #define TP_STATUS_COPY (1 << 1) | 
|  | 111 | #define TP_STATUS_LOSING (1 << 2) | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 112 | #define TP_STATUS_CSUMNOTREADY (1 << 3) | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 113 | #define TP_STATUS_VLAN_VALID (1 << 4) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 114 | #define TP_STATUS_BLK_TMO (1 << 5) | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 115 | #define TP_STATUS_VLAN_TPID_VALID (1 << 6) | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 116 | #define TP_STATUS_CSUM_VALID (1 << 7) | 
| Christopher Ferris | b7cef6d | 2023-05-09 19:04:15 +0000 | [diff] [blame] | 117 | #define TP_STATUS_GSO_TCP (1 << 8) | 
| Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 118 | #define TP_STATUS_AVAILABLE 0 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 119 | #define TP_STATUS_SEND_REQUEST (1 << 0) | 
|  | 120 | #define TP_STATUS_SENDING (1 << 1) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 121 | #define TP_STATUS_WRONG_FORMAT (1 << 2) | 
|  | 122 | #define TP_STATUS_TS_SOFTWARE (1 << 29) | 
|  | 123 | #define TP_STATUS_TS_SYS_HARDWARE (1 << 30) | 
| Christopher Ferris | b8a95e2 | 2019-10-02 18:29:20 -0700 | [diff] [blame] | 124 | #define TP_STATUS_TS_RAW_HARDWARE (1U << 31) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 125 | #define TP_FT_REQ_FILL_RXHASH 0x1 | 
|  | 126 | struct tpacket_hdr { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 127 | unsigned long tp_status; | 
|  | 128 | unsigned int tp_len; | 
|  | 129 | unsigned int tp_snaplen; | 
|  | 130 | unsigned short tp_mac; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 131 | unsigned short tp_net; | 
|  | 132 | unsigned int tp_sec; | 
|  | 133 | unsigned int tp_usec; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 134 | }; | 
|  | 135 | #define TPACKET_ALIGNMENT 16 | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 136 | #define TPACKET_ALIGN(x) (((x) + TPACKET_ALIGNMENT - 1) & ~(TPACKET_ALIGNMENT - 1)) | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 137 | #define TPACKET_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket_hdr)) + sizeof(struct sockaddr_ll)) | 
|  | 138 | struct tpacket2_hdr { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 139 | __u32 tp_status; | 
|  | 140 | __u32 tp_len; | 
|  | 141 | __u32 tp_snaplen; | 
|  | 142 | __u16 tp_mac; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 143 | __u16 tp_net; | 
|  | 144 | __u32 tp_sec; | 
|  | 145 | __u32 tp_nsec; | 
|  | 146 | __u16 tp_vlan_tci; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 147 | __u16 tp_vlan_tpid; | 
|  | 148 | __u8 tp_padding[4]; | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 149 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 150 | struct tpacket_hdr_variant1 { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 151 | __u32 tp_rxhash; | 
|  | 152 | __u32 tp_vlan_tci; | 
|  | 153 | __u16 tp_vlan_tpid; | 
|  | 154 | __u16 tp_padding; | 
| Christopher Ferris | 38062f9 | 2014-07-09 15:33:25 -0700 | [diff] [blame] | 155 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 156 | struct tpacket3_hdr { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 157 | __u32 tp_next_offset; | 
|  | 158 | __u32 tp_sec; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 159 | __u32 tp_nsec; | 
|  | 160 | __u32 tp_snaplen; | 
|  | 161 | __u32 tp_len; | 
|  | 162 | __u32 tp_status; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 163 | __u16 tp_mac; | 
|  | 164 | __u16 tp_net; | 
|  | 165 | union { | 
|  | 166 | struct tpacket_hdr_variant1 hv1; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 167 | }; | 
|  | 168 | __u8 tp_padding[8]; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 169 | }; | 
|  | 170 | struct tpacket_bd_ts { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 171 | unsigned int ts_sec; | 
|  | 172 | union { | 
|  | 173 | unsigned int ts_usec; | 
|  | 174 | unsigned int ts_nsec; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 175 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 176 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 177 | struct tpacket_hdr_v1 { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 178 | __u32 block_status; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 179 | __u32 num_pkts; | 
|  | 180 | __u32 offset_to_first_pkt; | 
|  | 181 | __u32 blk_len; | 
|  | 182 | __aligned_u64 seq_num; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 183 | struct tpacket_bd_ts ts_first_pkt, ts_last_pkt; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 184 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 185 | union tpacket_bd_header_u { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 186 | struct tpacket_hdr_v1 bh1; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 187 | }; | 
|  | 188 | struct tpacket_block_desc { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 189 | __u32 version; | 
|  | 190 | __u32 offset_to_priv; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 191 | union tpacket_bd_header_u hdr; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 192 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 193 | #define TPACKET2_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket2_hdr)) + sizeof(struct sockaddr_ll)) | 
|  | 194 | #define TPACKET3_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket3_hdr)) + sizeof(struct sockaddr_ll)) | 
|  | 195 | enum tpacket_versions { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 196 | TPACKET_V1, | 
|  | 197 | TPACKET_V2, | 
|  | 198 | TPACKET_V3 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 199 | }; | 
|  | 200 | struct tpacket_req { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 201 | unsigned int tp_block_size; | 
|  | 202 | unsigned int tp_block_nr; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 203 | unsigned int tp_frame_size; | 
|  | 204 | unsigned int tp_frame_nr; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 205 | }; | 
|  | 206 | struct tpacket_req3 { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 207 | unsigned int tp_block_size; | 
|  | 208 | unsigned int tp_block_nr; | 
|  | 209 | unsigned int tp_frame_size; | 
|  | 210 | unsigned int tp_frame_nr; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 211 | unsigned int tp_retire_blk_tov; | 
|  | 212 | unsigned int tp_sizeof_priv; | 
|  | 213 | unsigned int tp_feature_req_word; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 214 | }; | 
|  | 215 | union tpacket_req_u { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 216 | struct tpacket_req req; | 
|  | 217 | struct tpacket_req3 req3; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 218 | }; | 
|  | 219 | struct packet_mreq { | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 220 | int mr_ifindex; | 
|  | 221 | unsigned short mr_type; | 
|  | 222 | unsigned short mr_alen; | 
| Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 223 | unsigned char mr_address[8]; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 224 | }; | 
| Christopher Ferris | 05667cd | 2021-02-16 16:01:34 -0800 | [diff] [blame] | 225 | struct fanout_args { | 
|  | 226 | #ifdef __LITTLE_ENDIAN_BITFIELD | 
|  | 227 | __u16 id; | 
|  | 228 | __u16 type_flags; | 
|  | 229 | #else | 
|  | 230 | __u16 type_flags; | 
|  | 231 | __u16 id; | 
|  | 232 | #endif | 
|  | 233 | __u32 max_num_members; | 
|  | 234 | }; | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 235 | #define PACKET_MR_MULTICAST 0 | 
|  | 236 | #define PACKET_MR_PROMISC 1 | 
|  | 237 | #define PACKET_MR_ALLMULTI 2 | 
|  | 238 | #define PACKET_MR_UNICAST 3 | 
| Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 239 | #endif |