On Tue, Apr 16, 2024 at 07:14:43AM +0200, Michal Swiatkowski wrote:
> On Mon, Apr 15, 2024 at 11:10:50AM +0200, Jiri Pirko wrote:
> > Mon, Apr 15, 2024 at 10:39:39AM CEST, [email protected] 
> > wrote:
> > >On Fri, Apr 12, 2024 at 09:12:18AM +0200, Jiri Pirko wrote:
> > >> Fri, Apr 12, 2024 at 08:30:49AM CEST, [email protected] 
> > >> wrote:
> > >> >From: Piotr Raczynski <[email protected]>
> > 
> > [...]
> > 
> > >> >+static int
> > >> >+ice_devlink_port_fn_state_get(struct devlink_port *port,
> > >> >+                             enum devlink_port_fn_state *state,
> > >> >+                             enum devlink_port_fn_opstate *opstate,
> > >> >+                             struct netlink_ext_ack *extack)
> > >> >+{
> > >> >+       struct ice_dynamic_port *dyn_port;
> > >> >+
> > >> >+       dyn_port = ice_devlink_port_to_dyn(port);
> > >> >+
> > >> >+       if (dyn_port->active) {
> > >> >+               *state = DEVLINK_PORT_FN_STATE_ACTIVE;
> > >> >+               *opstate = DEVLINK_PORT_FN_OPSTATE_ATTACHED;
> > >> 
> > >> Interesting. This means that you don't distinguish between admin state
> > >> and operational state. Meaning, when user does activate, you atomically
> > >> achive the hw attachment and it is ready to go before activation cmd
> > >> returns, correct? I'm just making sure I understand the code.
> > >> 
> > >
> > >I am setting the dyn_port->active after the activation heppens, so it is
> > >true, when active is set it is ready to go.
> > >
> > >Do you mean that dyn_port->active should be set even before the activation 
> > >is
> > >finished? I mean when user only call devlink to active the port?
> > 
> > The devlink instance lock is taken the whole time, isn't it?
> > 
> 
> I don't take PF devlink lock here. Only subfunction devlink lock is
> taken during the initialization of subfunction.
>

Did you mean that the devlink lock is taken for DEVLINK_CMD_PORT_SET/GET
command? In this case, I think so, it is for the whole time of the
command execution.

Sorry I probably missed the point.

> > >
> > >> 
> > >> >+       } else {
> > >> >+               *state = DEVLINK_PORT_FN_STATE_INACTIVE;
> > >> >+               *opstate = DEVLINK_PORT_FN_OPSTATE_DETACHED;
> > >> >+       }
> > >> >+
> > >> >+       return 0;
> > >> >+}
> > >> >+
> > 
> > [...]

Reply via email to