|  | /** @file | 
|  | @brief IPv4 related functions | 
|  |  | 
|  | This is not to be included by the application. | 
|  | */ | 
|  |  | 
|  | /* | 
|  | * Copyright (c) 2016 Intel Corporation | 
|  | * | 
|  | * Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | * you may not use this file except in compliance with the License. | 
|  | * You may obtain a copy of the License at | 
|  | * | 
|  | *     http://www.apache.org/licenses/LICENSE-2.0 | 
|  | * | 
|  | * Unless required by applicable law or agreed to in writing, software | 
|  | * distributed under the License is distributed on an "AS IS" BASIS, | 
|  | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | * See the License for the specific language governing permissions and | 
|  | * limitations under the License. | 
|  | */ | 
|  |  | 
|  | #ifndef __IPV4_H | 
|  | #define __IPV4_H | 
|  |  | 
|  | #include <stdint.h> | 
|  |  | 
|  | #include <net/net_ip.h> | 
|  | #include <net/nbuf.h> | 
|  | #include <net/net_if.h> | 
|  | #include <net/net_context.h> | 
|  |  | 
|  | #include "ipv4.h" | 
|  |  | 
|  | /** | 
|  | * @brief Create IPv4 packet in provided net_buf. | 
|  | * | 
|  | * @param buf Network buffer | 
|  | * @param reserve Link layer reserve | 
|  | * @param src Source IPv4 address | 
|  | * @param dst Destination IPv4 address | 
|  | * @param iface Network interface | 
|  | * @param next_header Protocol type of the next header after IPv4 header. | 
|  | * | 
|  | * @return Return network buffer that contains the IPv4 packet. | 
|  | */ | 
|  | struct net_buf *net_ipv4_create_raw(struct net_buf *buf, | 
|  | uint16_t reserve, | 
|  | const struct in_addr *src, | 
|  | const struct in_addr *dst, | 
|  | struct net_if *iface, | 
|  | uint8_t next_header); | 
|  |  | 
|  | /** | 
|  | * @brief Create IPv4 packet in provided net_buf. | 
|  | * | 
|  | * @param context Network context for a connection | 
|  | * @param buf Network buffer | 
|  | * @param dst_addr Destination IPv4 address | 
|  | * | 
|  | * @return Return network buffer that contains the IPv6 packet. | 
|  | */ | 
|  | struct net_buf *net_ipv4_create(struct net_context *context, | 
|  | struct net_buf *buf, | 
|  | const struct in_addr *addr); | 
|  |  | 
|  | /** | 
|  | * @brief Finalize IPv4 packet. It should be called right before | 
|  | * sending the packet and after all the data has been added into | 
|  | * the packet. This function will set the length of the | 
|  | * packet and calculate the higher protocol checksum if needed. | 
|  | * | 
|  | * @param buf Network buffer | 
|  | * @param next_header Protocol type of the next header after IPv4 header. | 
|  | * | 
|  | * @return Return network buffer that contains the IPv4 packet. | 
|  | */ | 
|  | struct net_buf *net_ipv4_finalize_raw(struct net_buf *buf, | 
|  | uint8_t next_header); | 
|  |  | 
|  | /** | 
|  | * @brief Finalize IPv4 packet. It should be called right before | 
|  | * sending the packet and after all the data has been added into | 
|  | * the packet. This function will set the length of the | 
|  | * packet and calculate the higher protocol checksum if needed. | 
|  | * | 
|  | * @param context Network context for a connection | 
|  | * @param buf Network buffer | 
|  | * | 
|  | * @return Return network buffer that contains the IPv4 packet. | 
|  | */ | 
|  | struct net_buf *net_ipv4_finalize(struct net_context *context, | 
|  | struct net_buf *buf); | 
|  |  | 
|  | #endif /* __IPV4_H */ |