RE: [PATCH v2] r8152: Add support for setting MAC to system's Auxiliary MAC address

From: Mario_Limonciello
Date: Thu Jun 02 2016 - 14:32:48 EST


> -----Original Message-----
> From: Greg KH [mailto:gregkh@xxxxxxxxxxxxxxxxxxx]
> Sent: Thursday, June 2, 2016 12:48 PM
> To: Limonciello, Mario <Mario_Limonciello@xxxxxxxx>
> Cc: hayeswang@xxxxxxxxxxx; LKML <linux-kernel@xxxxxxxxxxxxxxx>; Netdev
> <netdev@xxxxxxxxxxxxxxx>; Linux USB <linux-usb@xxxxxxxxxxxxxxx>;
> pali.rohar@xxxxxxxxx; anthony.wong@xxxxxxxxxxxxx
> 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@xxxxxxxx>
> > ---
> > 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.