IPv6 fragmentation and reassembly. More...
#include "core/net.h"
#include "core/ip.h"
#include "ipv6/ipv6.h"
#include "ipv6/ipv6_frag.h"
#include "ipv6/icmpv6.h"
#include "mibs/ip_mib_module.h"
#include "debug.h"
Go to the source code of this file.
Macros | |
#define | TRACE_LEVEL IPV6_TRACE_LEVEL |
Functions | |
error_t | ipv6FragmentDatagram (NetInterface *interface, const Ipv6PseudoHeader *pseudoHeader, const NetBuffer *payload, size_t payloadOffset, size_t pathMtu, NetTxAncillary *ancillary) |
Fragment IPv6 datagram into smaller packets. More... | |
void | ipv6ParseFragmentHeader (NetInterface *interface, const NetBuffer *ipPacket, size_t ipPacketOffset, size_t fragHeaderOffset, size_t nextHeaderOffset, NetRxAncillary *ancillary) |
Parse Fragment header and reassemble original datagram. More... | |
void | ipv6FragTick (NetInterface *interface) |
Fragment reassembly timeout handler. More... | |
Ipv6FragDesc * | ipv6SearchFragQueue (NetInterface *interface, const Ipv6Header *packet, const Ipv6FragmentHeader *header) |
Search for a matching datagram in the reassembly queue. More... | |
void | ipv6FlushFragQueue (NetInterface *interface) |
Flush IPv6 reassembly queue. More... | |
Ipv6HoleDesc * | ipv6FindHole (Ipv6FragDesc *frag, uint16_t offset) |
Retrieve hole descriptor. More... | |
void | ipv6DumpHoleList (Ipv6FragDesc *frag) |
Dump hole descriptor list. More... | |
Variables | |
systime_t | ipv6FragTickCounter |
Detailed Description
IPv6 fragmentation and reassembly.
License
SPDX-License-Identifier: GPL-2.0-or-later
Copyright (C) 2010-2024 Oryx Embedded SARL. All rights reserved.
This file is part of CycloneTCP Open.
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- Version
- 2.4.4
Definition in file ipv6_frag.c.
Macro Definition Documentation
◆ TRACE_LEVEL
#define TRACE_LEVEL IPV6_TRACE_LEVEL |
Definition at line 32 of file ipv6_frag.c.
Function Documentation
◆ ipv6DumpHoleList()
void ipv6DumpHoleList | ( | Ipv6FragDesc * | frag | ) |
Dump hole descriptor list.
- Parameters
-
[in] frag IPv6 fragment descriptor
Definition at line 756 of file ipv6_frag.c.
◆ ipv6FindHole()
Ipv6HoleDesc* ipv6FindHole | ( | Ipv6FragDesc * | frag, |
uint16_t | offset | ||
) |
Retrieve hole descriptor.
- Parameters
-
[in] frag IPv6 fragment descriptor [in] offset Offset of the hole
- Returns
- A pointer to the hole descriptor is returned if the specified offset is valid. Otherwise NULL is returned
Definition at line 744 of file ipv6_frag.c.
◆ ipv6FlushFragQueue()
void ipv6FlushFragQueue | ( | NetInterface * | interface | ) |
Flush IPv6 reassembly queue.
- Parameters
-
[in] interface Underlying network interface
Definition at line 723 of file ipv6_frag.c.
◆ ipv6FragmentDatagram()
error_t ipv6FragmentDatagram | ( | NetInterface * | interface, |
const Ipv6PseudoHeader * | pseudoHeader, | ||
const NetBuffer * | payload, | ||
size_t | payloadOffset, | ||
size_t | pathMtu, | ||
NetTxAncillary * | ancillary | ||
) |
Fragment IPv6 datagram into smaller packets.
- Parameters
-
[in] interface Underlying network interface [in] pseudoHeader IPv6 pseudo header [in] payload Multi-part buffer containing the payload [in] payloadOffset Offset to the first payload byte [in] pathMtu PMTU value [in] ancillary Additional options passed to the stack along with the packet
- Returns
- Error code
Definition at line 62 of file ipv6_frag.c.
◆ ipv6FragTick()
void ipv6FragTick | ( | NetInterface * | interface | ) |
Fragment reassembly timeout handler.
This routine must be periodically called by the TCP/IP stack to handle IPv6 fragment reassembly timeout
- Parameters
-
[in] interface Underlying network interface
Definition at line 550 of file ipv6_frag.c.
◆ ipv6ParseFragmentHeader()
void ipv6ParseFragmentHeader | ( | NetInterface * | interface, |
const NetBuffer * | ipPacket, | ||
size_t | ipPacketOffset, | ||
size_t | fragHeaderOffset, | ||
size_t | nextHeaderOffset, | ||
NetRxAncillary * | ancillary | ||
) |
Parse Fragment header and reassemble original datagram.
- Parameters
-
[in] interface Underlying network interface [in] ipPacket Multi-part buffer containing the incoming IPv6 packet [in] ipPacketOffset Offset to the first byte of the IPv6 packet [in] fragHeaderOffset Offset to the Fragment header [in] nextHeaderOffset Offset to the Next Header field of the previous header [in] ancillary Additional options passed to the stack along with the packet
Definition at line 179 of file ipv6_frag.c.
◆ ipv6SearchFragQueue()
Ipv6FragDesc* ipv6SearchFragQueue | ( | NetInterface * | interface, |
const Ipv6Header * | packet, | ||
const Ipv6FragmentHeader * | header | ||
) |
Search for a matching datagram in the reassembly queue.
- Parameters
-
[in] interface Underlying network interface [in] packet Incoming IPv6 packet [in] header Pointer to the Fragment header
- Returns
- Matching fragment descriptor
Definition at line 619 of file ipv6_frag.c.
Variable Documentation
◆ ipv6FragTickCounter
systime_t ipv6FragTickCounter |
Definition at line 47 of file ipv6_frag.c.