summaryrefslogtreecommitdiffstats
path: root/translate.c
Commit message (Collapse)AuthorAgeFilesLines
* Move send_tun into tun.c as well.Lorenzo Colitti2014-12-081-5/+1
| | | | | | Also remove a redundant include in checksum.c. Change-Id: I0b8858343b1496f22904d3b316b6c435be0f648a
* Use a raw socket to send IPv6 packets instead of a tun.Lorenzo Colitti2014-06-111-6/+33
| | | | | | | This will allow us to bind the socket to a particular network. Bug: 15340961 Change-Id: I50857d372955f2b6f7035157c2968cda72c32585
* Make translate_packet take a fd instead of a tun header.Lorenzo Colitti2014-06-101-18/+7
| | | | | | | | This will make it easier to use separate fds for reading and writing in a future change. Bug: 15340961 Change-Id: I5b081b05765cae0488ac599be5738ce9737cae41
* Declare pos as clat_packet_index instead of intLorenzo Colitti2014-02-251-14/+12
| | | | | Bug: 11542311 Change-Id: Id5771c9685286b70a8ad283c259c7f83662e8b76
* Use uint8_t not char for binary data to avoid -Wall -Werror issues on x86 buildsBrian Carlstrom2014-02-241-17/+20
| | | | Change-Id: Ib61e67f15360c27c3ebf61f870a9482217c52357
* Support translating fragmented packets.Lorenzo Colitti2014-02-221-3/+51
| | | | | Bug: 11542311 Change-Id: I14a20b9ac669cdb5927f6ac26147bb0109099497
* Move translation entry point into translate.c.Lorenzo Colitti2014-02-141-9/+52
| | | | | | | | | | | The entry point to the translation code is currently called packet_handler and lives in clatd.c. Move it into translate.c and rename it to translate_packet, since that's what it does. Also get rid of some redundant includes. Bug: 11542311 Change-Id: I8529fb87f3a86ee6724fad54787c33a5e86c56ab
* Fix up checksums instead of recalculating them.Lorenzo Colitti2014-02-141-17/+32
| | | | | | | | | | | | Currently the checksums of translated packets are calculated from scratch by checksumming the translated packet. This is slow and does not work in the case of fragments, because the whole packet is not available. Instead, calculate the checksum by adjusting the checksum of the original packet. Bug: 11542311 Bug: 12116252 Change-Id: I6b78a94ca5bd96b13ee2653b6200551193b3dcc1
* Remove unused variablesBernhard Rosenkränzer2014-01-021-1/+0
| | | | | | | | Remove unused variables -- they cause warnings (and errors with -Werror) when building with clang 3.4. Change-Id: I03fff9b1b9d620763f41c8b31a19c4724726739c Signed-off-by: Bernhard Rosenkränzer <Bernhard.Rosenkranzer@linaro.org>
* Add generic IP packet code and use it for GRE.Lorenzo Colitti2013-11-251-0/+16
| | | | | Bug: 11542311 Change-Id: I174e0b268869bc77927feeee57003580c47c30f2
* Fix compiler warnings and enable -Wall -WerrorLorenzo Colitti2013-11-181-3/+2
| | | | Change-Id: I24847fa35644d92bff0fe31ccfc5c4b3e8705779
* Support translating ICMP errors.Lorenzo Colitti2013-04-121-31/+78
| | | | | | | | | When receiving ICMPv6 messages from IPv6-only nodes, use 255.0.0.<ttl> as a fake IPv4 source address. It's better than nothing. Bug: 8276725 Change-Id: Iae93f75764cb9cd875af9bb5f1862a0dce2c2fa7
* Improve checksum calculation and address checkingLorenzo Colitti2013-04-121-63/+91
| | | | | | | | | | | | | 1. Add a function that calculates the checksum of all the packet components starting from the specified position. This simplifies the code a bit and makes it easier to translate nested packets like ICMP error messages. 2. Don't hardcode IP source and destination addresses. This is required to translate ICMP error messages. Bug: 8276725 Change-Id: I2cae45683ae3943e508608fd0a140180dbc60823
* Pass around packet data instead of fdsLorenzo Colitti2013-04-121-242/+165
| | | | | | | | | | | | | | | | | The current code calls all the translation functions one after another, accumulating the translated packet into local variables on the stack and calling writev() at the end. This does not allow calling the translation functions re-entrantly, which is needed, for example, to translate ICMP errors (which contain the packet that caused them). Define a clat_packet type to wrap the array of iovecs and an enum of packet positions. Also clean up the code a bit: get rid of a fair bit of duplicated code (though there is still some left), get rid of some redundant memcpy statements, fix style issues, etc. Bug: 8276725 Change-Id: Ib58d2348894e82275234fc67dbdb1f82753f204f
* Treat the options as part of the TCP header.Lorenzo Colitti2013-04-121-40/+37
| | | | | | | | | | | | | | This simplifies the code and makes UDP and TCP look the same. It will also make it easier to implement nested translation in the future because there will only be one iovec array entry for the transport layer header, regardless of whether we are translating UDP or TCP and regardless of the presence of options. Also get rid of a couple of memcpy statements by pointing to the original data instead. Bug: 8276725 Change-Id: I6a702aefdf3a070eedfc6f7d3ebec21880ecc22b
* Pass in the length to pseudo checksum functionsLorenzo Colitti2013-04-091-5/+5
| | | | | | | | | | | | Currently, the pseudo-header checksum calculation functions get the transport layer length from the IP header. This requires that the length be known at IP header construction time, which does not allow transport layer translation functions to change the length of the packet later. Have the transport functions pass in the size directly. Bug: 8276725 Change-Id: I76a93f5e66181bec21d68f779c68c54090a77c33
* android clat serviceDaniel Drown2012-11-121-0/+404
This software provides the nat 4->6 translation needed for the "clat" part of the 464xlat standard. It is needed for better IPv4 application support while on an IPv6-only mobile network connection using 464xlat's nat64 (such as T-Mobile's IPv6 trial). A general diagram of how 464xlat works: http://dan.drown.org/android/clat/Clat-Plat.png Depends-on: I2392f8127dcd90d16b0f20ff31bcc5aa096db464 Change-Id: If2bc6916fc66fd4bca7cc241c83cfae839b82e15 Signed-off-by: Daniel Drown <dan-android@drown.org>