mirror of
https://anongit.gentoo.org/git/repo/gentoo.git
synced 2025-06-12 08:08:56 +02:00
This introduces the next version of r8152, but also includes a change in source. It is no longer possible to download the r8152 sources directly from realtek without passing a captcha challenge. So, I imported the tarballs directly into a new github project, documented the source and the SHA256, and am now using releases from that as the source. Signed-off-by: Jay Faulkner <jay@jvf.cc> Closes: https://github.com/gentoo/gentoo/pull/38573 [Eli: dropped stable keyword for bump] Signed-off-by: Eli Schwartz <eschwartz@gentoo.org>
134 lines
4.5 KiB
Diff
134 lines
4.5 KiB
Diff
From 32d026ab6b601cfe2882818921ba379cfbc3031e Mon Sep 17 00:00:00 2001
|
|
From: Jay Faulkner <jay@jvf.cc>
|
|
Date: Wed, 11 Sep 2024 20:30:33 -0700
|
|
Subject: [PATCH] Forward ported version of kernel 6.9.x fix patch
|
|
|
|
Original version sourced from below; has been forward-ported from
|
|
From: https://github.com/wget/realtek-r8152-linux/pull/41
|
|
From a5b3b4a882a3a637ccfa447dc7d2e84eac9ef0fc Mon Sep 17 00:00:00 2001
|
|
From: "oleg.hoefling" <oleg.hoefling@gmail.com>
|
|
---
|
|
r8152.c | 50 ++++++++++++++++++++++++++++++++++++++++++++++----
|
|
1 file changed, 46 insertions(+), 4 deletions(-)
|
|
|
|
diff --git a/r8152.c b/r8152.c
|
|
index cee3b23..4063525 100644
|
|
--- a/r8152.c
|
|
+++ b/r8152.c
|
|
@@ -1006,7 +1006,10 @@ struct r8152 {
|
|
int (*up)(struct r8152 *tp);
|
|
int (*down)(struct r8152 *tp);
|
|
void (*unload)(struct r8152 *tp);
|
|
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0)
|
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(6,9,0)
|
|
+ int (*eee_get)(struct r8152 *tp, struct ethtool_keee *eee);
|
|
+ int (*eee_set)(struct r8152 *tp, struct ethtool_keee *eee);
|
|
+#elif LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0)
|
|
int (*eee_get)(struct r8152 *tp, struct ethtool_eee *eee);
|
|
int (*eee_set)(struct r8152 *tp, struct ethtool_eee *eee);
|
|
#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0) */
|
|
@@ -23342,8 +23345,13 @@ static void rtl8152_get_strings(struct net_device *dev, u32 stringset, u8 *data)
|
|
}
|
|
}
|
|
|
|
+
|
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0)
|
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(6,9,0)
|
|
+static int r8152_get_eee(struct r8152 *tp, struct ethtool_keee *eee)
|
|
+#else
|
|
static int r8152_get_eee(struct r8152 *tp, struct ethtool_eee *eee)
|
|
+#endif
|
|
{
|
|
u32 lp, adv, supported = 0;
|
|
int ret;
|
|
@@ -23369,17 +23377,33 @@ static int r8152_get_eee(struct r8152 *tp, struct ethtool_eee *eee)
|
|
|
|
eee->eee_enabled = tp->eee_en;
|
|
eee->eee_active = !!(supported & adv & lp);
|
|
- eee->supported = supported;
|
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(6,9,0)
|
|
+ ethtool_convert_legacy_u32_to_link_mode(eee->supported, supported);
|
|
+ ethtool_convert_legacy_u32_to_link_mode(eee->advertised, tp->eee_adv);
|
|
+ ethtool_convert_legacy_u32_to_link_mode(eee->lp_advertised, lp);
|
|
+#else
|
|
+ eee->supported = supported;
|
|
eee->advertised = mmd_eee_adv_to_ethtool_adv_t(tp->eee_adv);
|
|
eee->lp_advertised = lp;
|
|
+#endif
|
|
|
|
out:
|
|
return (ret < 0) ? ret : 0;
|
|
}
|
|
|
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(6,9,0)
|
|
+static int r8152_set_eee(struct r8152 *tp, struct ethtool_keee *eee)
|
|
+#else
|
|
static int r8152_set_eee(struct r8152 *tp, struct ethtool_eee *eee)
|
|
+#endif
|
|
{
|
|
- u16 val = ethtool_adv_to_mmd_eee_adv_t(eee->advertised);
|
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(6,9,0)
|
|
+ u32 advertised = 0;
|
|
+ ethtool_convert_link_mode_to_legacy_u32(&advertised, eee->advertised);
|
|
+ u16 val = ethtool_adv_to_mmd_eee_adv_t(advertised);
|
|
+#else
|
|
+ u16 val = ethtool_adv_to_mmd_eee_adv_t(eee->advertised);
|
|
+#endif
|
|
|
|
tp->eee_en = eee->eee_enabled;
|
|
tp->eee_adv = val;
|
|
@@ -23387,7 +23411,11 @@ static int r8152_set_eee(struct r8152 *tp, struct ethtool_eee *eee)
|
|
return rtl_eee_enable(tp, tp->eee_en);
|
|
}
|
|
|
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(6,9,0)
|
|
+static int r8153_get_eee(struct r8152 *tp, struct ethtool_keee *eee)
|
|
+#else
|
|
static int r8153_get_eee(struct r8152 *tp, struct ethtool_eee *eee)
|
|
+#endif
|
|
{
|
|
u32 lp, adv, supported = 0;
|
|
u16 val;
|
|
@@ -23410,16 +23438,26 @@ static int r8153_get_eee(struct r8152 *tp, struct ethtool_eee *eee)
|
|
|
|
eee->eee_enabled = tp->eee_en;
|
|
eee->eee_active = !!(supported & adv & lp);
|
|
- eee->supported = supported;
|
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(6,9,0)
|
|
+ ethtool_convert_legacy_u32_to_link_mode(eee->supported, supported);
|
|
+ ethtool_convert_legacy_u32_to_link_mode(eee->advertised, tp->eee_adv);
|
|
+ ethtool_convert_legacy_u32_to_link_mode(eee->lp_advertised, lp);
|
|
+#else
|
|
+ eee->supported = supported;
|
|
eee->advertised = mmd_eee_adv_to_ethtool_adv_t(tp->eee_adv);
|
|
eee->lp_advertised = lp;
|
|
+#endif
|
|
|
|
out:
|
|
return (ret < 0) ? ret : 0;
|
|
}
|
|
|
|
static int
|
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(6,9,0)
|
|
+rtl_ethtool_get_eee(struct net_device *net, struct ethtool_keee *edata)
|
|
+#else
|
|
rtl_ethtool_get_eee(struct net_device *net, struct ethtool_eee *edata)
|
|
+#endif
|
|
{
|
|
struct r8152 *tp = netdev_priv(net);
|
|
int ret;
|
|
@@ -23446,7 +23484,11 @@ out:
|
|
}
|
|
|
|
static int
|
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(6,9,0)
|
|
+rtl_ethtool_set_eee(struct net_device *net, struct ethtool_keee *edata)
|
|
+#else
|
|
rtl_ethtool_set_eee(struct net_device *net, struct ethtool_eee *edata)
|
|
+#endif
|
|
{
|
|
struct r8152 *tp = netdev_priv(net);
|
|
int ret;
|
|
--
|
|
2.46.0
|
|
|