[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <2d81e70165b8447d92b873eafeaeded7@ausx13mpc124.AMER.DELL.COM>
Date: Thu, 2 Jun 2016 18:32:42 +0000
From: <Mario_Limonciello@...l.com>
To: <gregkh@...uxfoundation.org>
CC: <hayeswang@...ltek.com>, <linux-kernel@...r.kernel.org>,
<netdev@...r.kernel.org>, <linux-usb@...r.kernel.org>,
<pali.rohar@...il.com>, <anthony.wong@...onical.com>
Subject: RE: [PATCH v2] r8152: Add support for setting MAC to system's
Auxiliary MAC address
> -----Original Message-----
> From: Greg KH [mailto:gregkh@...uxfoundation.org]
> Sent: Thursday, June 2, 2016 12:48 PM
> To: Limonciello, Mario <Mario_Limonciello@...l.com>
> Cc: hayeswang@...ltek.com; LKML <linux-kernel@...r.kernel.org>; Netdev
> <netdev@...r.kernel.org>; Linux USB <linux-usb@...r.kernel.org>;
> pali.rohar@...il.com; anthony.wong@...onical.com
> Subject: Re: [PATCH v2] r8152: Add support for setting MAC to system's
> Auxiliary MAC address
>
> On Thu, Jun 02, 2016 at 11:58:07AM -0500, Mario Limonciello wrote:
> > Dell systems with Type-C ports have support for a persistent system
> > specific MAC address when used with Dell Type-C docks and dongles.
> > This means a dock plugged into two different systems will show different
> > (but persistent) MAC addresses. Dell Type-C docks and dongles use the
> > r8152 driver.
> >
> > This information for the system's persistent MAC address is burned in
> when
> > the HW is built and available under _SB\AMAC in the DSDT at runtime.
> >
> > More information about the technology is available here:
> > http://www.dell.com/support/article/us/en/04/SLN301147
> >
> > Signed-off-by: Mario Limonciello <mario_limonciello@...l.com>
> > ---
> > drivers/net/usb/r8152.c | 53
> +++++++++++++++++++++++++++++++++++++++++++++++++
> > 1 file changed, 53 insertions(+)
> >
> > diff --git a/drivers/net/usb/r8152.c b/drivers/net/usb/r8152.c
> > index 3f9f6ed..6dea542 100644
> > --- a/drivers/net/usb/r8152.c
> > +++ b/drivers/net/usb/r8152.c
> > @@ -26,6 +26,8 @@
> > #include <linux/mdio.h>
> > #include <linux/usb/cdc.h>
> > #include <linux/suspend.h>
> > +#include <linux/acpi.h>
> > +#include <linux/dmi.h>
> >
> > /* Information for net-next */
> > #define NETNEXT_VERSION "08"
> > @@ -500,6 +502,7 @@ enum rtl8152_flags {
> > SELECTIVE_SUSPEND,
> > PHY_RESET,
> > SCHEDULE_NAPI,
> > + MAC_PASSTHRU = 0,
>
> Does setting that to 0 really work? You just did this for two enum
> values, what is the compiler supposed to do?
Very silly of me. I was rushing to send a v2.
I'm surprised this worked. Shouldn't be assigned to anything.
>
> > };
> >
> > /* Define these values to match your device */
> > @@ -653,6 +656,7 @@ enum tx_csum_stat {
> > */
> > static const int multicast_filter_limit = 32;
> > static unsigned int agg_buf_sz = 16384;
> > +static bool mac_passthru_active;
>
> very generic name for a platform-specific feature :(
Once this is broken up into an x86 platform provided method I'll rename this
to platform_mac_active (or something similar).
>
>
> >
> > #define RTL_LIMITED_TSO_SIZE (agg_buf_sz - sizeof(struct tx_desc) -
> \
> > VLAN_ETH_HLEN - VLAN_HLEN)
> > @@ -1030,6 +1034,49 @@ out1:
> > return ret;
> > }
> >
> > +static int get_auxiliary_addr(struct r8152 *tp, struct sockaddr *sa)
>
> What about the platform mac address api that was pointed out?
I mentioned this in the cover letter - I haven't gotten a chance to move it over there yet.
I sent v2 before I did so that you can see what I've been doing as it was relevant to your
other comments.
>
> > +{
> > + acpi_status status;
> > + struct acpi_buffer buffer = { ACPI_ALLOCATE_BUFFER, NULL };
> > + union acpi_object *obj;
> > + int ret = -1;
> > + unsigned char buf[6];
> > +
> > + if (!dmi_name_in_vendors("Dell Inc.") || mac_passthru_active)
> > + return -1;
>
> Don't make up random error values, please use "real" ones.
OK.
>
> And you want to check this for all Dell devices? Please be model
> specific, I doubt a bunch of Dell servers wants to run this code...
>
Tracking model specific is really going to turn into a giant list never ending list.
To drill down more specifically, I can match on chassis too.
> > +
> > + /* returns _AUXMAC_#AABBCCDDEEFF# */
> > + status = acpi_evaluate_object(NULL, "\\_SB.AMAC", NULL, &buffer);
> > + obj = (union acpi_object *)buffer.pointer;
> > + if (ACPI_SUCCESS(status)) {
> > + if (obj->type != ACPI_TYPE_BUFFER ||
> > + obj->string.length != 0x17) {
> > + pr_warn("r8152: get_auxiliary_addr: Invalid buffer");
> > + goto amacout;
> > + }
> > + if (strncmp(obj->string.pointer, "_AUXMAC_#", 9) != 0) {
> > + pr_warn("r8152: get_auxiliary_addr: Invalid header");
> > + goto amacout;
> > + }
> > + ret = hex2bin(buf, obj->string.pointer + 9, 6);
> > + if (ret < 0) {
> > + pr_warn("r8152: get_auxiliary_addr: Invalid MAC");
> > + goto amacout;
> > + }
> > + memcpy(sa->sa_data, buf, 6);
> > + ether_addr_copy(tp->netdev->dev_addr, sa->sa_data);
> > + netdev_info(tp->netdev, "Using system MAC address
> %pM\n",
> > + sa->sa_data);
> > + set_bit(MAC_PASSTHRU, &tp->flags);
> > + mac_passthru_active = true;
> > + ret = 1;
>
> 1 is not a "all is good" return value.
OK will switch to 0.
Powered by blists - more mailing lists