Skip to content

Commit

Permalink
ethtool: Merge branch 'sohorx-ethtool/channels'
Browse files Browse the repository at this point in the history
Bug-Url: svinota#1192
  • Loading branch information
svinota committed Apr 2, 2024
2 parents 0212c57 + 2adeb6d commit 59b4a72
Show file tree
Hide file tree
Showing 2 changed files with 64 additions and 0 deletions.
35 changes: 35 additions & 0 deletions pyroute2/ethtool/ethtool.py
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,31 @@ def to_ioctl(ioctl_features, eth_features):
ioctl_features[feature.name] = feature.enable


class EthtoolChannels(
namedtuple(
'EthtoolChannels',
(
"max_rx",
"max_tx",
"max_other",
"max_combined",
"rx_count",
"tx_count",
"other_count",
"combined_count",
),
)
):
@classmethod
def from_ioctl(cls, channels):
return cls(**{k: getattr(channels, k) for k in cls._fields})

@staticmethod
def to_ioctl(ioctl_channels, eth_channel):
for key, val in eth_channel.items():
setattr(ioctl_channels, key, val)


class EthtoolWakeOnLan(namedtuple('EthtoolWolMode', ('modes', 'sopass'))):
@classmethod
def from_netlink(cls, nl_wol):
Expand Down Expand Up @@ -465,6 +490,16 @@ def set_features(self, ifname, features):
EthtoolFeatures.to_ioctl(ioctl_features, features)
self._with_ioctl.set_features(ioctl_features)

def get_channels(self, ifname):
self._with_ioctl.change_ifname(ifname)
return EthtoolChannels.from_ioctl(self._with_ioctl.get_channels())

def set_channels(self, ifname, channels):
self._with_ioctl.change_ifname(ifname)
ioctl_channels = self._with_ioctl.get_channels()
EthtoolChannels.to_ioctl(ioctl_channels, channels)
self._with_ioctl.set_channels(ioctl_channels)

def get_coalesce(self, ifname):
self._with_ioctl.change_ifname(ifname)
return EthtoolCoalesce.from_ioctl(self._with_ioctl.get_coalesce())
Expand Down
29 changes: 29 additions & 0 deletions pyroute2/ethtool/ioctl.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@
ETHTOOL_GFLAGS = 0x00000025
ETHTOOL_GFEATURES = 0x0000003A
ETHTOOL_SFEATURES = 0x0000003B
ETHTOOL_GCHANNELS = 0x0000003C
ETHTOOL_SCHANNELS = 0x0000003D
ETHTOOL_GLINKSETTINGS = 0x0000004C

ETHTOOL_GSTRINGS = 0x0000001B
Expand Down Expand Up @@ -339,6 +341,21 @@ class EthtoolSfeatures(ctypes.Structure):
]


class EthtoolChannels(DictStruct):
_pack_ = 1
_fields_ = [
("cmd", ctypes.c_uint32),
("max_rx", ctypes.c_uint32),
("max_tx", ctypes.c_uint32),
("max_other", ctypes.c_uint32),
("max_combined", ctypes.c_uint32),
("rx_count", ctypes.c_uint32),
("tx_count", ctypes.c_uint32),
("other_count", ctypes.c_uint32),
("combined_count", ctypes.c_uint32),
]


class FeatureState(ctypes.Structure):
_fields_ = [("off_flags", ctypes.c_uint32), ("features", EthtoolGfeatures)]

Expand Down Expand Up @@ -369,6 +386,7 @@ class IfReqData(ctypes.Union):
("gstats", ctypes.POINTER(None)),
("gfeatures", ctypes.POINTER(EthtoolGfeatures)),
("sfeatures", ctypes.POINTER(EthtoolSfeatures)),
("channels", ctypes.POINTER(EthtoolChannels)),
("glinksettings", ctypes.POINTER(IoctlEthtoolLinkSettings)),
("wolinfo", ctypes.POINTER(EthtoolWolInfo)),
("rings", ctypes.POINTER(EthtoolRingParam)),
Expand Down Expand Up @@ -562,6 +580,17 @@ def set_features(self, features):
self.ifreq.sfeatures = ctypes.pointer(features._cmd_set)
return self.ioctl()

def get_channels(self):
cmd = EthtoolChannels(cmd=ETHTOOL_GCHANNELS)
self.ifreq.channels = ctypes.pointer(cmd)
self.ioctl()
return cmd

def set_channels(self, channels):
channels.cmd = ETHTOOL_SCHANNELS
self.ifreq.channels = ctypes.pointer(channels)
return self.ioctl()

def get_cmd(self):
cmd = EthtoolCmd(cmd=ETHTOOL_GSET)
self.ifreq.ifr_data = ctypes.pointer(cmd)
Expand Down

0 comments on commit 59b4a72

Please sign in to comment.