xref: /freebsd/sys/dev/ocs_fc/ocs_sm.c (revision 95ee2897e98f5d444f26ed2334cc7c439f9c16c6)
1*ef270ab1SKenneth D. Merry /*-
2*ef270ab1SKenneth D. Merry  * Copyright (c) 2017 Broadcom. All rights reserved.
3*ef270ab1SKenneth D. Merry  * The term "Broadcom" refers to Broadcom Limited and/or its subsidiaries.
4*ef270ab1SKenneth D. Merry  *
5*ef270ab1SKenneth D. Merry  * Redistribution and use in source and binary forms, with or without
6*ef270ab1SKenneth D. Merry  * modification, are permitted provided that the following conditions are met:
7*ef270ab1SKenneth D. Merry  *
8*ef270ab1SKenneth D. Merry  * 1. Redistributions of source code must retain the above copyright notice,
9*ef270ab1SKenneth D. Merry  *    this list of conditions and the following disclaimer.
10*ef270ab1SKenneth D. Merry  *
11*ef270ab1SKenneth D. Merry  * 2. Redistributions in binary form must reproduce the above copyright notice,
12*ef270ab1SKenneth D. Merry  *    this list of conditions and the following disclaimer in the documentation
13*ef270ab1SKenneth D. Merry  *    and/or other materials provided with the distribution.
14*ef270ab1SKenneth D. Merry  *
15*ef270ab1SKenneth D. Merry  * 3. Neither the name of the copyright holder nor the names of its contributors
16*ef270ab1SKenneth D. Merry  *    may be used to endorse or promote products derived from this software
17*ef270ab1SKenneth D. Merry  *    without specific prior written permission.
18*ef270ab1SKenneth D. Merry  *
19*ef270ab1SKenneth D. Merry  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20*ef270ab1SKenneth D. Merry  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21*ef270ab1SKenneth D. Merry  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22*ef270ab1SKenneth D. Merry  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23*ef270ab1SKenneth D. Merry  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24*ef270ab1SKenneth D. Merry  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25*ef270ab1SKenneth D. Merry  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26*ef270ab1SKenneth D. Merry  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27*ef270ab1SKenneth D. Merry  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28*ef270ab1SKenneth D. Merry  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29*ef270ab1SKenneth D. Merry  * POSSIBILITY OF SUCH DAMAGE.
30*ef270ab1SKenneth D. Merry  */
31*ef270ab1SKenneth D. Merry 
32*ef270ab1SKenneth D. Merry /**
33*ef270ab1SKenneth D. Merry  * @file
34*ef270ab1SKenneth D. Merry  * Generic state machine framework.
35*ef270ab1SKenneth D. Merry  */
36*ef270ab1SKenneth D. Merry 
37*ef270ab1SKenneth D. Merry #include "ocs_os.h"
38*ef270ab1SKenneth D. Merry #include "ocs_sm.h"
39*ef270ab1SKenneth D. Merry 
40*ef270ab1SKenneth D. Merry const char *ocs_sm_id[] = {
41*ef270ab1SKenneth D. Merry 	"common",
42*ef270ab1SKenneth D. Merry 	"domain",
43*ef270ab1SKenneth D. Merry 	"login"
44*ef270ab1SKenneth D. Merry };
45*ef270ab1SKenneth D. Merry 
46*ef270ab1SKenneth D. Merry /**
47*ef270ab1SKenneth D. Merry  * @brief Post an event to a context.
48*ef270ab1SKenneth D. Merry  *
49*ef270ab1SKenneth D. Merry  * @param ctx State machine context
50*ef270ab1SKenneth D. Merry  * @param evt Event to post
51*ef270ab1SKenneth D. Merry  * @param data Event-specific data (if any)
52*ef270ab1SKenneth D. Merry  *
53*ef270ab1SKenneth D. Merry  * @return 0 if successfully posted event; -1 if state machine
54*ef270ab1SKenneth D. Merry  *         is disabled
55*ef270ab1SKenneth D. Merry  */
56*ef270ab1SKenneth D. Merry int
ocs_sm_post_event(ocs_sm_ctx_t * ctx,ocs_sm_event_t evt,void * data)57*ef270ab1SKenneth D. Merry ocs_sm_post_event(ocs_sm_ctx_t *ctx, ocs_sm_event_t evt, void *data)
58*ef270ab1SKenneth D. Merry {
59*ef270ab1SKenneth D. Merry 	if (ctx->current_state) {
60*ef270ab1SKenneth D. Merry 		ctx->current_state(ctx, evt, data);
61*ef270ab1SKenneth D. Merry 		return 0;
62*ef270ab1SKenneth D. Merry 	} else {
63*ef270ab1SKenneth D. Merry 		return -1;
64*ef270ab1SKenneth D. Merry 	}
65*ef270ab1SKenneth D. Merry }
66*ef270ab1SKenneth D. Merry 
67*ef270ab1SKenneth D. Merry /**
68*ef270ab1SKenneth D. Merry  * @brief Transition to a new state.
69*ef270ab1SKenneth D. Merry  */
70*ef270ab1SKenneth D. Merry void
ocs_sm_transition(ocs_sm_ctx_t * ctx,ocs_sm_function_t state,void * data)71*ef270ab1SKenneth D. Merry ocs_sm_transition(ocs_sm_ctx_t *ctx, ocs_sm_function_t state, void *data)
72*ef270ab1SKenneth D. Merry {
73*ef270ab1SKenneth D. Merry 	if (ctx->current_state == state) {
74*ef270ab1SKenneth D. Merry 		ocs_sm_post_event(ctx, OCS_EVT_REENTER, data);
75*ef270ab1SKenneth D. Merry 	} else {
76*ef270ab1SKenneth D. Merry 		ocs_sm_post_event(ctx, OCS_EVT_EXIT, data);
77*ef270ab1SKenneth D. Merry 		ctx->current_state = state;
78*ef270ab1SKenneth D. Merry 		ocs_sm_post_event(ctx, OCS_EVT_ENTER, data);
79*ef270ab1SKenneth D. Merry 	}
80*ef270ab1SKenneth D. Merry }
81*ef270ab1SKenneth D. Merry 
82*ef270ab1SKenneth D. Merry /**
83*ef270ab1SKenneth D. Merry  * @brief Disable further state machine processing.
84*ef270ab1SKenneth D. Merry  */
85*ef270ab1SKenneth D. Merry void
ocs_sm_disable(ocs_sm_ctx_t * ctx)86*ef270ab1SKenneth D. Merry ocs_sm_disable(ocs_sm_ctx_t *ctx)
87*ef270ab1SKenneth D. Merry {
88*ef270ab1SKenneth D. Merry 	ctx->current_state = NULL;
89*ef270ab1SKenneth D. Merry }
90*ef270ab1SKenneth D. Merry 
ocs_sm_event_name(ocs_sm_event_t evt)91*ef270ab1SKenneth D. Merry const char *ocs_sm_event_name(ocs_sm_event_t evt)
92*ef270ab1SKenneth D. Merry {
93*ef270ab1SKenneth D. Merry 	switch (evt) {
94*ef270ab1SKenneth D. Merry 	#define RETEVT(x)	case x:		return #x;
95*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ENTER)
96*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_REENTER)
97*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_EXIT)
98*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SHUTDOWN)
99*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RESPONSE)
100*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RESUME)
101*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_TIMER_EXPIRED)
102*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ERROR)
103*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SRRS_ELS_REQ_OK)
104*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SRRS_ELS_CMPL_OK)
105*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SRRS_ELS_REQ_FAIL)
106*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SRRS_ELS_CMPL_FAIL)
107*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SRRS_ELS_REQ_RJT)
108*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_NODE_ATTACH_OK)
109*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_NODE_ATTACH_FAIL)
110*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_NODE_FREE_OK)
111*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ELS_REQ_TIMEOUT)
112*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ELS_REQ_ABORTED)
113*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ABORT_ELS)
114*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ELS_ABORT_CMPL)
115*ef270ab1SKenneth D. Merry 
116*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_DOMAIN_FOUND)
117*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_DOMAIN_ALLOC_OK)
118*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_DOMAIN_ALLOC_FAIL)
119*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_DOMAIN_REQ_ATTACH)
120*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_DOMAIN_ATTACH_OK)
121*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_DOMAIN_ATTACH_FAIL)
122*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_DOMAIN_LOST)
123*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_DOMAIN_FREE_OK)
124*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_DOMAIN_FREE_FAIL)
125*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_HW_DOMAIN_REQ_ATTACH)
126*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_HW_DOMAIN_REQ_FREE)
127*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ALL_CHILD_NODES_FREE)
128*ef270ab1SKenneth D. Merry 
129*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SPORT_ALLOC_OK)
130*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SPORT_ALLOC_FAIL)
131*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SPORT_ATTACH_OK)
132*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SPORT_ATTACH_FAIL)
133*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SPORT_FREE_OK)
134*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SPORT_FREE_FAIL)
135*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SPORT_TOPOLOGY_NOTIFY)
136*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_HW_PORT_ALLOC_OK)
137*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_HW_PORT_ALLOC_FAIL)
138*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_HW_PORT_ATTACH_OK)
139*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_HW_PORT_REQ_ATTACH)
140*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_HW_PORT_REQ_FREE)
141*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_HW_PORT_FREE_OK)
142*ef270ab1SKenneth D. Merry 
143*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_NODE_FREE_FAIL)
144*ef270ab1SKenneth D. Merry 
145*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ABTS_RCVD)
146*ef270ab1SKenneth D. Merry 
147*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_NODE_MISSING)
148*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_NODE_REFOUND)
149*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SHUTDOWN_IMPLICIT_LOGO)
150*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SHUTDOWN_EXPLICIT_LOGO)
151*ef270ab1SKenneth D. Merry 
152*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ELS_FRAME)
153*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_PLOGI_RCVD)
154*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_FLOGI_RCVD)
155*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_LOGO_RCVD)
156*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_PRLI_RCVD)
157*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_PRLO_RCVD)
158*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_PDISC_RCVD)
159*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_FDISC_RCVD)
160*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ADISC_RCVD)
161*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RSCN_RCVD)
162*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_SCR_RCVD)
163*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ELS_RCVD)
164*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_LAST)
165*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_FCP_CMD_RCVD)
166*ef270ab1SKenneth D. Merry 
167*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RFT_ID_RCVD)
168*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RFF_ID_RCVD)
169*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_GNN_ID_RCVD)
170*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_GPN_ID_RCVD)
171*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_GFPN_ID_RCVD)
172*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_GFF_ID_RCVD)
173*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_GID_FT_RCVD)
174*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_GID_PT_RCVD)
175*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RPN_ID_RCVD)
176*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RNN_ID_RCVD)
177*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RCS_ID_RCVD)
178*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RSNN_NN_RCVD)
179*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RSPN_ID_RCVD)
180*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RHBA_RCVD)
181*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RPA_RCVD)
182*ef270ab1SKenneth D. Merry 
183*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_GIDPT_DELAY_EXPIRED)
184*ef270ab1SKenneth D. Merry 
185*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ABORT_IO)
186*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ABORT_IO_NO_RESP)
187*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_IO_CMPL)
188*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_IO_CMPL_ERRORS)
189*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_RESP_CMPL)
190*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_ABORT_CMPL)
191*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_NODE_ACTIVE_IO_LIST_EMPTY)
192*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_NODE_DEL_INI_COMPLETE)
193*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_NODE_DEL_TGT_COMPLETE)
194*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_IO_ABORTED_BY_TMF)
195*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_IO_ABORT_IGNORED)
196*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_IO_FIRST_BURST)
197*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_IO_FIRST_BURST_ERR)
198*ef270ab1SKenneth D. Merry 	RETEVT(OCS_EVT_IO_FIRST_BURST_ABORTED)
199*ef270ab1SKenneth D. Merry 
200*ef270ab1SKenneth D. Merry 	default:
201*ef270ab1SKenneth D. Merry 		break;
202*ef270ab1SKenneth D. Merry 	#undef RETEVT
203*ef270ab1SKenneth D. Merry 	}
204*ef270ab1SKenneth D. Merry 	return "unknown";
205*ef270ab1SKenneth D. Merry }
206