Message ID | 20210830231050.5951-1-jsmart2021@gmail.com |
---|---|
State | New |
Headers | show |
Series | elx: efct: Fix void-pointer-to-enum-cast warning for efc_nport_topology | expand |
On Mon, 30 Aug 2021 16:10:50 -0700, James Smart wrote: > the kernel test robot flagged an warning for ".../efc_device.c:932:6: > warning: cast to smaller integer type 'enum efc_nport_topology' from > 'void *'" > > For the topology events, the "arg" field is generically defined as a > void * and is used to pass different arguments. Most of the arguments > are pointers to data structures. But for the > EFC_EVT_NPORT_TOPOLOGY_NOTIFY event, the argument is an enum value, and > the code is typecasting the void * to an enum generating the warning. > > [...] Applied to 5.15/scsi-fixes, thanks! [1/1] elx: efct: Fix void-pointer-to-enum-cast warning for efc_nport_topology https://git.kernel.org/mkp/scsi/c/96fafe7c6523 -- Martin K. Petersen Oracle Linux Engineering
diff --git a/drivers/scsi/elx/libefc/efc_device.c b/drivers/scsi/elx/libefc/efc_device.c index 725ca2a23fb2..52be01333c6e 100644 --- a/drivers/scsi/elx/libefc/efc_device.c +++ b/drivers/scsi/elx/libefc/efc_device.c @@ -928,22 +928,21 @@ __efc_d_wait_topology_notify(struct efc_sm_ctx *ctx, break; case EFC_EVT_NPORT_TOPOLOGY_NOTIFY: { - enum efc_nport_topology topology = - (enum efc_nport_topology)arg; + enum efc_nport_topology *topology = arg; WARN_ON(node->nport->domain->attached); WARN_ON(node->send_ls_acc != EFC_NODE_SEND_LS_ACC_PLOGI); node_printf(node, "topology notification, topology=%d\n", - topology); + *topology); /* At the time the PLOGI was received, the topology was unknown, * so we didn't know which node would perform the domain attach: * 1. The node from which the PLOGI was sent (p2p) or * 2. The node to which the FLOGI was sent (fabric). */ - if (topology == EFC_NPORT_TOPO_P2P) { + if (*topology == EFC_NPORT_TOPO_P2P) { /* if this is p2p, need to attach to the domain using * the d_id from the PLOGI received */ diff --git a/drivers/scsi/elx/libefc/efc_fabric.c b/drivers/scsi/elx/libefc/efc_fabric.c index d397220d9e54..3270ce40196c 100644 --- a/drivers/scsi/elx/libefc/efc_fabric.c +++ b/drivers/scsi/elx/libefc/efc_fabric.c @@ -107,7 +107,6 @@ void efc_fabric_notify_topology(struct efc_node *node) { struct efc_node *tmp_node; - enum efc_nport_topology topology = node->nport->topology; unsigned long index; /* @@ -118,7 +117,7 @@ efc_fabric_notify_topology(struct efc_node *node) if (tmp_node != node) { efc_node_post_event(tmp_node, EFC_EVT_NPORT_TOPOLOGY_NOTIFY, - (void *)topology); + &node->nport->topology); } } }