mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-15 16:26:45 +07:00
fsl/fman: check dereferencing null pointer
Add a safe check to avoid dereferencing null pointer
Fixes: 57ba4c9b56
("fsl/fman: Add FMan MAC support")
Signed-off-by: Florinel Iordache <florinel.iordache@nxp.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
cc79fd8f55
commit
cc5d229a12
@ -1200,7 +1200,7 @@ int dtsec_del_hash_mac_address(struct fman_mac *dtsec, enet_addr_t *eth_addr)
|
|||||||
list_for_each(pos,
|
list_for_each(pos,
|
||||||
&dtsec->multicast_addr_hash->lsts[bucket]) {
|
&dtsec->multicast_addr_hash->lsts[bucket]) {
|
||||||
hash_entry = ETH_HASH_ENTRY_OBJ(pos);
|
hash_entry = ETH_HASH_ENTRY_OBJ(pos);
|
||||||
if (hash_entry->addr == addr) {
|
if (hash_entry && hash_entry->addr == addr) {
|
||||||
list_del_init(&hash_entry->node);
|
list_del_init(&hash_entry->node);
|
||||||
kfree(hash_entry);
|
kfree(hash_entry);
|
||||||
break;
|
break;
|
||||||
@ -1213,7 +1213,7 @@ int dtsec_del_hash_mac_address(struct fman_mac *dtsec, enet_addr_t *eth_addr)
|
|||||||
list_for_each(pos,
|
list_for_each(pos,
|
||||||
&dtsec->unicast_addr_hash->lsts[bucket]) {
|
&dtsec->unicast_addr_hash->lsts[bucket]) {
|
||||||
hash_entry = ETH_HASH_ENTRY_OBJ(pos);
|
hash_entry = ETH_HASH_ENTRY_OBJ(pos);
|
||||||
if (hash_entry->addr == addr) {
|
if (hash_entry && hash_entry->addr == addr) {
|
||||||
list_del_init(&hash_entry->node);
|
list_del_init(&hash_entry->node);
|
||||||
kfree(hash_entry);
|
kfree(hash_entry);
|
||||||
break;
|
break;
|
||||||
|
@ -981,7 +981,7 @@ int memac_del_hash_mac_address(struct fman_mac *memac, enet_addr_t *eth_addr)
|
|||||||
|
|
||||||
list_for_each(pos, &memac->multicast_addr_hash->lsts[hash]) {
|
list_for_each(pos, &memac->multicast_addr_hash->lsts[hash]) {
|
||||||
hash_entry = ETH_HASH_ENTRY_OBJ(pos);
|
hash_entry = ETH_HASH_ENTRY_OBJ(pos);
|
||||||
if (hash_entry->addr == addr) {
|
if (hash_entry && hash_entry->addr == addr) {
|
||||||
list_del_init(&hash_entry->node);
|
list_del_init(&hash_entry->node);
|
||||||
kfree(hash_entry);
|
kfree(hash_entry);
|
||||||
break;
|
break;
|
||||||
|
@ -626,7 +626,7 @@ int tgec_del_hash_mac_address(struct fman_mac *tgec, enet_addr_t *eth_addr)
|
|||||||
|
|
||||||
list_for_each(pos, &tgec->multicast_addr_hash->lsts[hash]) {
|
list_for_each(pos, &tgec->multicast_addr_hash->lsts[hash]) {
|
||||||
hash_entry = ETH_HASH_ENTRY_OBJ(pos);
|
hash_entry = ETH_HASH_ENTRY_OBJ(pos);
|
||||||
if (hash_entry->addr == addr) {
|
if (hash_entry && hash_entry->addr == addr) {
|
||||||
list_del_init(&hash_entry->node);
|
list_del_init(&hash_entry->node);
|
||||||
kfree(hash_entry);
|
kfree(hash_entry);
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user