wireless: at76c50x: allocating too much data

This is a cut and paste mistake, sizeof(struct mib_local) was intended
instead of sizeof(struct mib_phy).  The call to at76_get_mib() uses
sizeof(struct mib_local) correctly, although I changed that to
sizeof(*m) for style reasons after discussion with some of the wireless
maintainers.

The current code works fine because mib_phy structs are larger than
mib_local structs.  But we may as well clean it up.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
Dan Carpenter 2012-04-21 15:23:44 +03:00 committed by John W. Linville
parent 8b5bed90a5
commit 62c50543ce

View file

@ -1122,12 +1122,12 @@ static void at76_dump_mib_phy(struct at76_priv *priv)
static void at76_dump_mib_local(struct at76_priv *priv) static void at76_dump_mib_local(struct at76_priv *priv)
{ {
int ret; int ret;
struct mib_local *m = kmalloc(sizeof(struct mib_phy), GFP_KERNEL); struct mib_local *m = kmalloc(sizeof(*m), GFP_KERNEL);
if (!m) if (!m)
return; return;
ret = at76_get_mib(priv->udev, MIB_LOCAL, m, sizeof(struct mib_local)); ret = at76_get_mib(priv->udev, MIB_LOCAL, m, sizeof(*m));
if (ret < 0) { if (ret < 0) {
wiphy_err(priv->hw->wiphy, wiphy_err(priv->hw->wiphy,
"at76_get_mib (LOCAL) failed: %d\n", ret); "at76_get_mib (LOCAL) failed: %d\n", ret);