Thread (29 messages) 29 messages, 6 authors, 2018-07-20

[PATCH 4/5] net: add support for nvmem to eth_platform_get_mac_address()

From: Bartosz Golaszewski <hidden>
Date: 2018-07-19 21:24:41
Also in: linux-omap, lkml, netdev

2018-07-19 19:47 GMT+02:00 Russell King - ARM Linux [off-list ref]:
On Wed, Jul 18, 2018 at 06:10:34PM +0200, Bartosz Golaszewski wrote:
quoted
@@ -544,6 +548,31 @@ int eth_platform_get_mac_address(struct device *dev, u8 *mac_addr)
                      from = "arch callback";
      }

+     if (!addr) {
+             nvmem = nvmem_cell_get(dev, "mac-address");
+             if (IS_ERR(nvmem) && PTR_ERR(nvmem) == -EPROBE_DEFER)
This is way too verbose.  To quote Al Viro from earlier today:

<viro> sigh...
<viro>         if (IS_ERR(link) && PTR_ERR(link) == -EEXIST)
<viro> what the hell is wrong with if (link == ERR_PTR(-EEXIST))?

I wonder why so many people haven't heard of pointer comparison... ;)

IS_ERR(ERR_PTR(-EPROBE_DEFER)) is always true - if it wasn't, then
we'd be in for problems.

So, if you're asserting that nvmem is ERR_PTR(-EPROBE_DEFER) then
there's no need to do the IS_ERR(nvmem) must also be true.  Hence, a
simple pointer comparison is sufficient:

                if (nvmem == ERR_PTR(-EPROBE_DEFER))
                        return -EPROBE_DEFER;
Hi Russell,

this issue is gone now in v3 but thanks for the example - I somehow
never thought about it.

Bart
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help