net_util: split create_socket() into AF_UNIX and AF_INET varieties

Some host kernels are IPv6-only, and they cannot make an AF_INET socket.
The tun ioctls such as SIOCGIFHWADDR work with an AF_UNIX socket, which
all host kernels should have.

Signed-off-by: Barret Rhoden <brho@google.com>
This commit is contained in:
Barret Rhoden 2022-03-02 10:38:36 -05:00 committed by Sebastien Boeuf
parent 2c3908eed9
commit cbf5068e17
2 changed files with 21 additions and 7 deletions

View File

@ -77,7 +77,7 @@ fn create_sockaddr(ip_addr: net::Ipv4Addr) -> net_gen::sockaddr {
unsafe { mem::transmute(addr_in) } unsafe { mem::transmute(addr_in) }
} }
fn create_socket() -> Result<net::UdpSocket> { fn create_inet_socket() -> Result<net::UdpSocket> {
// This is safe since we check the return value. // This is safe since we check the return value.
let sock = unsafe { libc::socket(libc::AF_INET, libc::SOCK_DGRAM, 0) }; let sock = unsafe { libc::socket(libc::AF_INET, libc::SOCK_DGRAM, 0) };
if sock < 0 { if sock < 0 {
@ -88,6 +88,17 @@ fn create_socket() -> Result<net::UdpSocket> {
Ok(unsafe { net::UdpSocket::from_raw_fd(sock) }) Ok(unsafe { net::UdpSocket::from_raw_fd(sock) })
} }
fn create_unix_socket() -> Result<net::UdpSocket> {
// This is safe since we check the return value.
let sock = unsafe { libc::socket(libc::AF_UNIX, libc::SOCK_DGRAM, 0) };
if sock < 0 {
return Err(Error::CreateSocket(IoError::last_os_error()));
}
// This is safe; nothing else will use or hold onto the raw sock fd.
Ok(unsafe { net::UdpSocket::from_raw_fd(sock) })
}
fn vnet_hdr_len() -> usize { fn vnet_hdr_len() -> usize {
std::mem::size_of::<virtio_net_hdr_v1>() std::mem::size_of::<virtio_net_hdr_v1>()
} }

View File

@ -5,7 +5,10 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the THIRD-PARTY file. // found in the THIRD-PARTY file.
use super::{create_sockaddr, create_socket, vnet_hdr_len, Error as NetUtilError, MacAddr}; use super::{
create_inet_socket, create_sockaddr, create_unix_socket, vnet_hdr_len, Error as NetUtilError,
MacAddr,
};
use crate::mac::MAC_ADDR_LEN; use crate::mac::MAC_ADDR_LEN;
use std::fs::File; use std::fs::File;
use std::io::{Error as IoError, Read, Result as IoResult, Write}; use std::io::{Error as IoError, Read, Result as IoResult, Write};
@ -196,7 +199,7 @@ impl Tap {
/// Set the host-side IP address for the tap interface. /// Set the host-side IP address for the tap interface.
pub fn set_ip_addr(&self, ip_addr: net::Ipv4Addr) -> Result<()> { pub fn set_ip_addr(&self, ip_addr: net::Ipv4Addr) -> Result<()> {
let sock = create_socket().map_err(Error::NetUtil)?; let sock = create_inet_socket().map_err(Error::NetUtil)?;
let addr = create_sockaddr(ip_addr); let addr = create_sockaddr(ip_addr);
let mut ifreq = self.get_ifreq(); let mut ifreq = self.get_ifreq();
@ -224,7 +227,7 @@ impl Tap {
return Ok(()); return Ok(());
} }
let sock = create_socket().map_err(Error::NetUtil)?; let sock = create_unix_socket().map_err(Error::NetUtil)?;
let mut ifreq = self.get_ifreq(); let mut ifreq = self.get_ifreq();
@ -254,7 +257,7 @@ impl Tap {
/// Get mac addr for tap interface. /// Get mac addr for tap interface.
pub fn get_mac_addr(&self) -> Result<MacAddr> { pub fn get_mac_addr(&self) -> Result<MacAddr> {
let sock = create_socket().map_err(Error::NetUtil)?; let sock = create_unix_socket().map_err(Error::NetUtil)?;
let ifreq = self.get_ifreq(); let ifreq = self.get_ifreq();
@ -275,7 +278,7 @@ impl Tap {
/// Set the netmask for the subnet that the tap interface will exist on. /// Set the netmask for the subnet that the tap interface will exist on.
pub fn set_netmask(&self, netmask: net::Ipv4Addr) -> Result<()> { pub fn set_netmask(&self, netmask: net::Ipv4Addr) -> Result<()> {
let sock = create_socket().map_err(Error::NetUtil)?; let sock = create_inet_socket().map_err(Error::NetUtil)?;
let addr = create_sockaddr(netmask); let addr = create_sockaddr(netmask);
let mut ifreq = self.get_ifreq(); let mut ifreq = self.get_ifreq();
@ -306,7 +309,7 @@ impl Tap {
/// Enable the tap interface. /// Enable the tap interface.
pub fn enable(&self) -> Result<()> { pub fn enable(&self) -> Result<()> {
let sock = create_socket().map_err(Error::NetUtil)?; let sock = create_unix_socket().map_err(Error::NetUtil)?;
let mut ifreq = self.get_ifreq(); let mut ifreq = self.get_ifreq();