| Daniel Drown | a45056e | 2012-03-23 10:42:54 -0500 | [diff] [blame] | 1 | /* | 
|  | 2 | * Copyright 2011 Daniel Drown | 
|  | 3 | * | 
|  | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | 5 | * you may not use this file except in compliance with the License. | 
|  | 6 | * You may obtain a copy of the License at | 
|  | 7 | * | 
|  | 8 | * http://www.apache.org/licenses/LICENSE-2.0 | 
|  | 9 | * | 
|  | 10 | * Unless required by applicable law or agreed to in writing, software | 
|  | 11 | * distributed under the License is distributed on an "AS IS" BASIS, | 
|  | 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | 13 | * See the License for the specific language governing permissions and | 
|  | 14 | * limitations under the License. | 
|  | 15 | * | 
| Lorenzo Colitti | eb92f48 | 2019-01-04 14:59:11 +0900 | [diff] [blame] | 16 | * clatd.h - main routines used by clatd | 
| Daniel Drown | a45056e | 2012-03-23 10:42:54 -0500 | [diff] [blame] | 17 | */ | 
|  | 18 | #ifndef __CLATD_H__ | 
|  | 19 | #define __CLATD_H__ | 
|  | 20 |  | 
| Maciej Żenczykowski | 8ab7e13 | 2021-02-03 17:15:41 -0800 | [diff] [blame] | 21 | #include <signal.h> | 
| Maciej Żenczykowski | 716518d | 2019-04-08 17:46:48 -0700 | [diff] [blame] | 22 | #include <stdlib.h> | 
| Lorenzo Colitti | 6b2007a | 2014-12-08 12:53:05 +0900 | [diff] [blame] | 23 | #include <sys/uio.h> | 
|  | 24 |  | 
| Lorenzo Colitti | eb92f48 | 2019-01-04 14:59:11 +0900 | [diff] [blame] | 25 | struct tun_data; | 
|  | 26 |  | 
| Maciej Żenczykowski | 97de334 | 2023-01-18 17:36:22 +0000 | [diff] [blame] | 27 | // IPv4 header has a u16 total length field, for maximum L3 mtu of 0xFFFF. | 
|  | 28 | // | 
|  | 29 | // Translating IPv4 to IPv6 requires removing the IPv4 header (20) and adding | 
|  | 30 | // an IPv6 header (40), possibly with an extra ipv6 fragment extension header (8). | 
|  | 31 | // | 
|  | 32 | // As such the maximum IPv4 L3 mtu size is 0xFFFF (by u16 tot_len field) | 
|  | 33 | // and the maximum IPv6 L3 mtu size is 0xFFFF + 28 (which is larger) | 
|  | 34 | // | 
|  | 35 | // A received non-jumbogram IPv6 frame could potentially be u16 payload_len = 0xFFFF | 
|  | 36 | // + sizeof ipv6 header = 40, bytes in size.  But such a packet cannot be meaningfully | 
|  | 37 | // converted to IPv4 (it's too large).  As such the restriction is the same: 0xFFFF + 28 | 
|  | 38 | // | 
|  | 39 | // (since there's no jumbogram support in IPv4, IPv6 jumbograms cannot be meaningfully | 
|  | 40 | // converted to IPv4 anyway, and are thus entirely unsupported) | 
| Maciej Żenczykowski | f3eeff9 | 2023-03-13 21:50:01 +0000 | [diff] [blame] | 41 | #define MAXMTU (0xFFFF + 28) | 
| Maciej Żenczykowski | bea3f7f | 2023-01-30 22:29:59 +0000 | [diff] [blame] | 42 |  | 
| Maciej Żenczykowski | f3eeff9 | 2023-03-13 21:50:01 +0000 | [diff] [blame] | 43 | // logcat_hexdump() maximum binary data length, this is the maximum packet size | 
|  | 44 | // plus some extra space for various headers: | 
|  | 45 | //   struct tun_pi (4 bytes) | 
|  | 46 | //   struct virtio_net_hdr (10 bytes) | 
|  | 47 | //   ethernet (14 bytes), potentially including vlan tag (4) or tags (8 or 12) | 
|  | 48 | // plus some extra just-in-case headroom, because it doesn't hurt. | 
|  | 49 | #define MAXDUMPLEN (64 + MAXMTU) | 
| Maciej Żenczykowski | bea3f7f | 2023-01-30 22:29:59 +0000 | [diff] [blame] | 50 |  | 
| Maciej Żenczykowski | d775fd7 | 2023-03-15 17:10:18 +0000 | [diff] [blame] | 51 | #define CLATD_VERSION "1.7" | 
| Daniel Drown | a45056e | 2012-03-23 10:42:54 -0500 | [diff] [blame] | 52 |  | 
| Lorenzo Colitti | dce3ddf | 2014-08-25 16:07:12 -0700 | [diff] [blame] | 53 | #define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0])) | 
|  | 54 |  | 
| Maciej Żenczykowski | 8ab7e13 | 2021-02-03 17:15:41 -0800 | [diff] [blame] | 55 | extern volatile sig_atomic_t running; | 
|  | 56 |  | 
| Lorenzo Colitti | eb92f48 | 2019-01-04 14:59:11 +0900 | [diff] [blame] | 57 | void event_loop(struct tun_data *tunnel); | 
| Maciej Żenczykowski | 716518d | 2019-04-08 17:46:48 -0700 | [diff] [blame] | 58 |  | 
|  | 59 | /* function: parse_int | 
|  | 60 | * parses a string as a decimal/hex/octal signed integer | 
|  | 61 | *   str - the string to parse | 
|  | 62 | *   out - the signed integer to write to, gets clobbered on failure | 
|  | 63 | */ | 
|  | 64 | static inline int parse_int(const char *str, int *out) { | 
|  | 65 | char *end_ptr; | 
|  | 66 | *out = strtol(str, &end_ptr, 0); | 
|  | 67 | return *str && !*end_ptr; | 
|  | 68 | } | 
|  | 69 |  | 
|  | 70 | /* function: parse_unsigned | 
|  | 71 | * parses a string as a decimal/hex/octal unsigned integer | 
|  | 72 | *   str - the string to parse | 
|  | 73 | *   out - the unsigned integer to write to, gets clobbered on failure | 
|  | 74 | */ | 
|  | 75 | static inline int parse_unsigned(const char *str, unsigned *out) { | 
|  | 76 | char *end_ptr; | 
|  | 77 | *out = strtoul(str, &end_ptr, 0); | 
|  | 78 | return *str && !*end_ptr; | 
|  | 79 | } | 
| Lorenzo Colitti | 6b2007a | 2014-12-08 12:53:05 +0900 | [diff] [blame] | 80 |  | 
| Daniel Drown | a45056e | 2012-03-23 10:42:54 -0500 | [diff] [blame] | 81 | #endif /* __CLATD_H__ */ |