2023-11-07 12:40:14 +11:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
* Copyright Red Hat
|
|
|
|
* Author: David Gibson <david@gibson.dropbear.id.au>
|
|
|
|
*
|
|
|
|
* Passt/pasta interface types and IDs
|
|
|
|
*/
|
|
|
|
#ifndef PIF_H
|
|
|
|
#define PIF_H
|
|
|
|
|
2024-07-18 15:26:28 +10:00
|
|
|
union inany_addr;
|
|
|
|
union sockaddr_inany;
|
|
|
|
|
2023-11-07 12:40:14 +11:00
|
|
|
/**
|
|
|
|
* enum pif_type - Type of passt/pasta interface ("pif")
|
|
|
|
*
|
|
|
|
* pifs can be an L4 level channel (sockets) or an L2 level channel (tap device
|
|
|
|
* or qemu socket).
|
|
|
|
*/
|
|
|
|
enum pif_type {
|
|
|
|
/* Invalid or not present pif */
|
|
|
|
PIF_NONE = 0,
|
|
|
|
/* Host socket interface */
|
|
|
|
PIF_HOST,
|
|
|
|
/* Qemu socket or namespace tuntap interface */
|
|
|
|
PIF_TAP,
|
|
|
|
/* Namespace socket interface for splicing */
|
|
|
|
PIF_SPLICE,
|
2023-11-30 13:02:20 +11:00
|
|
|
|
|
|
|
PIF_NUM_TYPES,
|
2023-11-07 12:40:14 +11:00
|
|
|
};
|
|
|
|
|
2023-11-30 13:02:20 +11:00
|
|
|
#define PIF_NAMELEN 8
|
|
|
|
|
|
|
|
extern const char *pif_type_str[];
|
|
|
|
|
|
|
|
static inline const char *pif_type(enum pif_type pt)
|
|
|
|
{
|
|
|
|
if (pt < PIF_NUM_TYPES)
|
|
|
|
return pif_type_str[pt];
|
|
|
|
else
|
|
|
|
return "?";
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline const char *pif_name(uint8_t pif)
|
|
|
|
{
|
|
|
|
return pif_type(pif);
|
|
|
|
}
|
|
|
|
|
2024-07-18 15:26:28 +10:00
|
|
|
/**
|
|
|
|
* pif_is_socket() - Is interface implemented via L4 sockets?
|
|
|
|
* @pif: pif to check
|
|
|
|
*
|
|
|
|
* Return: true of @pif is an L4 socket based interface, otherwise false
|
|
|
|
*/
|
|
|
|
static inline bool pif_is_socket(uint8_t pif)
|
|
|
|
{
|
|
|
|
return pif == PIF_HOST || pif == PIF_SPLICE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void pif_sockaddr(const struct ctx *c, union sockaddr_inany *sa, socklen_t *sl,
|
|
|
|
uint8_t pif, const union inany_addr *addr, in_port_t port);
|
|
|
|
|
2023-11-07 12:40:14 +11:00
|
|
|
#endif /* PIF_H */
|