xref: /freebsd/sys/dev/isci/scil/scic_sds_remote_device.h (revision 3823d5e198425b4f5e5a80267d195769d1063773)
1 /*-
2  * This file is provided under a dual BSD/GPLv2 license.  When using or
3  * redistributing this file, you may do so under either license.
4  *
5  * GPL LICENSE SUMMARY
6  *
7  * Copyright(c) 2008 - 2011 Intel Corporation. All rights reserved.
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of version 2 of the GNU General Public License as
11  * published by the Free Software Foundation.
12  *
13  * This program is distributed in the hope that it will be useful, but
14  * WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
21  * The full GNU General Public License is included in this distribution
22  * in the file called LICENSE.GPL.
23  *
24  * BSD LICENSE
25  *
26  * Copyright(c) 2008 - 2011 Intel Corporation. All rights reserved.
27  * All rights reserved.
28  *
29  * Redistribution and use in source and binary forms, with or without
30  * modification, are permitted provided that the following conditions
31  * are met:
32  *
33  *   * Redistributions of source code must retain the above copyright
34  *     notice, this list of conditions and the following disclaimer.
35  *   * Redistributions in binary form must reproduce the above copyright
36  *     notice, this list of conditions and the following disclaimer in
37  *     the documentation and/or other materials provided with the
38  *     distribution.
39  *
40  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
41  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
42  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
43  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
44  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
45  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
46  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
47  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
48  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
49  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
50  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
51  *
52  * $FreeBSD$
53  */
54 #ifndef _SCIC_SDS_REMOTE_DEVICE_H_
55 #define _SCIC_SDS_REMOTE_DEVICE_H_
56 
57 /**
58  * @file
59  *
60  * @brief This file contains the structures, constants, and prototypes for the
61  *        SCIC_SDS_REMOTE_DEVICE object.
62  */
63 
64 #ifdef __cplusplus
65 extern "C" {
66 #endif // __cplusplus
67 
68 #include <dev/isci/scil/intel_sas.h>
69 #include <dev/isci/scil/sci_base_remote_device.h>
70 #include <dev/isci/scil/sci_base_request.h>
71 #include <dev/isci/scil/sci_base_state_machine_logger.h>
72 #include <dev/isci/scil/scu_remote_node_context.h>
73 #include <dev/isci/scil/scic_sds_remote_node_context.h>
74 
75 struct SCIC_SDS_CONTROLLER;
76 struct SCIC_SDS_PORT;
77 struct SCIC_SDS_REQUEST;
78 struct SCIC_SDS_REMOTE_DEVICE_STATE_HANDLER;
79 
80 /**
81  * @enum SCIC_SDS_SSP_REMOTE_DEVICE_READY_SUBSTATES
82  *
83  * This is the enumeration of the ready substates for the
84  * SCIC_SDS_REMOTE_DEVICE.
85  */
86 enum SCIC_SDS_SSP_REMOTE_DEVICE_READY_SUBSTATES
87 {
88    /**
89     * This is the initial state for the remote device ready substate.
90     */
91    SCIC_SDS_SSP_REMOTE_DEVICE_READY_SUBSTATE_INITIAL,
92 
93    /**
94     * This is the ready operational substate for the remote device.  This is the
95     * normal operational state for a remote device.
96     */
97    SCIC_SDS_SSP_REMOTE_DEVICE_READY_SUBSTATE_OPERATIONAL,
98 
99    /**
100     * This is the suspended state for the remote device.  This is the state that
101     * the device is placed in when a RNC suspend is received by the SCU hardware.
102     */
103    SCIC_SDS_SSP_REMOTE_DEVICE_READY_SUBSTATE_SUSPENDED,
104 
105    /**
106     * This is the final state that the device is placed in before a change to the
107     * base state machine.
108     */
109    SCIC_SDS_SSP_REMOTE_DEVICE_READY_SUBSTATE_FINAL,
110 
111    SCIC_SDS_SSP_REMOTE_DEVICE_READY_MAX_SUBSTATES
112 };
113 
114 /**
115  * @enum SCIC_SDS_STP_REMOTE_DEVICE_READY_SUBSTATES
116  *
117  * This is the enumeration for the SCIC_SDS_REMOTE_DEVICE ready substates for
118  * the STP remote device.
119  */
120 enum SCIC_SDS_STP_REMOTE_DEVICE_READY_SUBSTATES
121 {
122    /**
123     * This is the idle substate for the stp remote device.  When there are no
124     * active IO for the device it is in this state.
125     */
126    SCIC_SDS_STP_REMOTE_DEVICE_READY_SUBSTATE_IDLE,
127 
128    /**
129     * This is the command state for for the STP remote device.  This state is
130     * entered when the device is processing a non-NCQ command.  The device object
131     * will fail any new start IO requests until this command is complete.
132     */
133    SCIC_SDS_STP_REMOTE_DEVICE_READY_SUBSTATE_CMD,
134 
135    /**
136     * This is the NCQ state for the STP remote device.  This state is entered
137     * when the device is processing an NCQ reuqest.  It will remain in this state
138     * so long as there is one or more NCQ requests being processed.
139     */
140    SCIC_SDS_STP_REMOTE_DEVICE_READY_SUBSTATE_NCQ,
141 
142    /**
143     * This is the NCQ error state for the STP remote device.  This state is
144     * entered when an SDB error FIS is received by the device object while in the
145     * NCQ state.  The device object will only accept a READ LOG command while in
146     * this state.
147     */
148    SCIC_SDS_STP_REMOTE_DEVICE_READY_SUBSTATE_NCQ_ERROR,
149 
150 #if !defined(DISABLE_ATAPI)
151    /**
152     * This is the ATAPI error state for the STP ATAPI remote device.  This state is
153     * entered when ATAPI device sends error status FIS without data while the device
154     * object is in CMD state. A suspension event is expected in this state. The device
155     * object will resume right away.
156     */
157    SCIC_SDS_STP_REMOTE_DEVICE_READY_SUBSTATE_ATAPI_ERROR,
158 #endif
159 
160    /**
161     * This is the READY substate indicates the device is waiting for the RESET task
162     * coming to be recovered from certain hardware specific error.
163     */
164    SCIC_SDS_STP_REMOTE_DEVICE_READY_SUBSTATE_AWAIT_RESET,
165 
166    SCIC_SDS_STP_REMOTE_DEVICE_READY_MAX_SUBSTATES
167 };
168 
169 
170 /**
171  * @enum SCIC_SDS_SMP_REMOTE_DEVICE_READY_SUBSTATES
172  *
173  * This is the enumeration of the ready substates for the SMP REMOTE DEVICE.
174  */
175 
176 enum SCIC_SDS_SMP_REMOTE_DEVICE_READY_SUBSTATES
177 {
178    /**
179     * This is the ready operational substate for the remote device.  This is the
180     * normal operational state for a remote device.
181     */
182    SCIC_SDS_SMP_REMOTE_DEVICE_READY_SUBSTATE_IDLE,
183 
184    /**
185     * This is the suspended state for the remote device.  This is the state that
186     * the device is placed in when a RNC suspend is received by the SCU hardware.
187     */
188    SCIC_SDS_SMP_REMOTE_DEVICE_READY_SUBSTATE_CMD,
189 
190    SCIC_SDS_SMP_REMOTE_DEVICE_READY_MAX_SUBSTATES
191 };
192 
193 
194 
195 
196 /**
197  * @struct SCIC_SDS_REMOTE_DEVICE
198  *
199  * @brief  This structure contains the data for an SCU implementation of
200  *         the SCU Core device data.
201  */
202 typedef struct SCIC_SDS_REMOTE_DEVICE
203 {
204    /**
205     * This field is the common base for all remote device objects.
206     */
207    SCI_BASE_REMOTE_DEVICE_T parent;
208 
209    /**
210     * This field is the programmed device port width.  This value is written to
211     * the RCN data structure to tell the SCU how many open connections this
212     * device can have.
213     */
214    U32 device_port_width;
215 
216    /**
217     * This field is the programmed connection rate for this remote device.  It is
218     * used to program the TC with the maximum allowed connection rate.
219     */
220    SCI_SAS_LINK_RATE connection_rate;
221 
222    /**
223     * This field contains the allowed target protocols for this remote device.
224     */
225    SMP_DISCOVER_RESPONSE_PROTOCOLS_T target_protocols;
226 
227    /**
228     * This field contains the device SAS address.
229     */
230    SCI_SAS_ADDRESS_T device_address;
231 
232    /**
233     * This filed is assinged the value of TRUE if the device is directly attached
234     * to the port.
235     */
236    BOOL is_direct_attached;
237 
238 #if !defined(DISABLE_ATAPI)
239    /**
240     * This filed is assinged the value of TRUE if the device is an ATAPI device.
241     */
242    BOOL is_atapi;
243 #endif
244 
245    /**
246     * This filed contains a pointer back to the port to which this device is
247     * assigned.
248     */
249    struct SCIC_SDS_PORT *owning_port;
250 
251    /**
252     * This field contains the SCU silicon remote node context specific
253     * information.
254     */
255    struct SCIC_SDS_REMOTE_NODE_CONTEXT * rnc;
256 
257    /**
258     * This field contains the stated request count for the remote device.  The
259     * device can not reach the SCI_BASE_REMOTE_DEVICE_STATE_STOPPED until all
260     * requests are complete and the rnc_posted value is FALSE.
261     */
262    U32 started_request_count;
263 
264    /**
265     * This field contains a pointer to the working request object.  It is only
266     * used only for SATA requests since the unsolicited frames we get from the
267     * hardware have no Tag value to look up the io request object.
268     */
269    struct SCIC_SDS_REQUEST * working_request;
270 
271    /**
272     * This field contains the reason for the remote device going not_ready.  It is
273     * assigned in the state handlers and used in the state transition.
274     */
275    U32 not_ready_reason;
276 
277    /**
278     * This field is TRUE if this remote device has an initialzied ready substate
279     * machine. SSP devices do not have a ready substate machine and STP devices
280     * have a ready substate machine.
281     */
282    BOOL has_ready_substate_machine;
283 
284    /**
285     * This field contains the state machine for the ready substate machine for
286     * this SCIC_SDS_REMOTE_DEVICE object.
287     */
288    SCI_BASE_STATE_MACHINE_T ready_substate_machine;
289 
290    /**
291     * This field maintains the set of state handlers for the remote device
292     * object.  These are changed each time the remote device enters a new state.
293     */
294    struct SCIC_SDS_REMOTE_DEVICE_STATE_HANDLER *state_handlers;
295 
296    #ifdef SCI_LOGGING
297    /**
298     * This field conatins the ready substate machine logger.  The logger will
299     * emit a message each time the ready substate machine changes state.
300     */
301    SCI_BASE_STATE_MACHINE_LOGGER_T ready_substate_machine_logger;
302    #endif
303 
304 } SCIC_SDS_REMOTE_DEVICE_T;
305 
306 
307 typedef SCI_STATUS (*SCIC_SDS_REMOTE_DEVICE_HANDLER_T)(
308                                  SCIC_SDS_REMOTE_DEVICE_T *this_device);
309 
310 typedef SCI_STATUS (*SCIC_SDS_REMOTE_DEVICE_SUSPEND_HANDLER_T)(
311                                  SCIC_SDS_REMOTE_DEVICE_T *this_device,
312                                  U32                       suspend_type);
313 
314 typedef SCI_STATUS (*SCIC_SDS_REMOTE_DEVICE_RESUME_HANDLER_T)(
315                                  SCIC_SDS_REMOTE_DEVICE_T *this_device);
316 
317 typedef SCI_STATUS (*SCIC_SDS_REMOTE_DEVICE_FRAME_HANDLER_T)(
318                                   SCIC_SDS_REMOTE_DEVICE_T *this_device,
319                                   U32                       frame_index);
320 
321 typedef SCI_STATUS (*SCIC_SDS_REMOTE_DEVICE_EVENT_HANDLER_T)(
322                                   SCIC_SDS_REMOTE_DEVICE_T *this_device,
323                                   U32                       event_code);
324 
325 typedef void (*SCIC_SDS_REMOTE_DEVICE_READY_NOT_READY_HANDLER_T)(
326                                   SCIC_SDS_REMOTE_DEVICE_T *this_device);
327 
328 /**
329  * @struct SCIC_SDS_REMOTE_DEVICE_STATE_HANDLER
330  * @brief This structure conains the state handlers that are needed to
331  *        process requests for the SCU remote device objects.
332  */
333 typedef struct SCIC_SDS_REMOTE_DEVICE_STATE_HANDLER
334 {
335    SCI_BASE_REMOTE_DEVICE_STATE_HANDLER_T parent;
336 
337    SCIC_SDS_REMOTE_DEVICE_SUSPEND_HANDLER_T suspend_handler;
338    SCIC_SDS_REMOTE_DEVICE_RESUME_HANDLER_T  resume_handler;
339 
340    SCIC_SDS_REMOTE_DEVICE_EVENT_HANDLER_T event_handler;
341    SCIC_SDS_REMOTE_DEVICE_FRAME_HANDLER_T frame_handler;
342 
343 } SCIC_SDS_REMOTE_DEVICE_STATE_HANDLER_T;
344 
345 
346 extern SCI_BASE_STATE_T scic_sds_remote_device_state_table[];
347 extern SCI_BASE_STATE_T scic_sds_ssp_remote_device_ready_substate_table[];
348 extern SCI_BASE_STATE_T scic_sds_stp_remote_device_ready_substate_table[];
349 extern SCI_BASE_STATE_T scic_sds_smp_remote_device_ready_substate_table[];
350 
351 extern SCIC_SDS_REMOTE_DEVICE_STATE_HANDLER_T
352                scic_sds_remote_device_state_handler_table[];
353 extern SCIC_SDS_REMOTE_DEVICE_STATE_HANDLER_T
354                scic_sds_ssp_remote_device_ready_substate_handler_table[];
355 extern SCIC_SDS_REMOTE_DEVICE_STATE_HANDLER_T
356                scic_sds_stp_remote_device_ready_substate_handler_table[];
357 extern SCIC_SDS_REMOTE_DEVICE_STATE_HANDLER_T
358                scic_sds_smp_remote_device_ready_substate_handler_table[];
359 
360 /**
361  * This macro incrments the request count for this device
362  */
363 #define scic_sds_remote_device_increment_request_count(this_device) \
364    ((this_device)->started_request_count++)
365 
366 /**
367  * This macro decrements the request count for this device.  This count
368  * will never decrment past 0.
369  */
370 #define scic_sds_remote_device_decrement_request_count(this_device) \
371    ((this_device)->started_request_count > 0 ? \
372       (this_device)->started_request_count-- : 0)
373 
374 /**
375  * This is a helper macro to return the current device request count.
376  */
377 #define scic_sds_remote_device_get_request_count(this_device) \
378    ((this_device)->started_request_count)
379 
380 /**
381  * This macro returns the owning port of this remote device obejct.
382  */
383 #define scic_sds_remote_device_get_port(this_device) \
384    ((this_device)->owning_port)
385 
386 /**
387  * This macro returns the controller object that contains this device
388  * object
389  */
390 #define scic_sds_remote_device_get_controller(this_device) \
391    scic_sds_port_get_controller(scic_sds_remote_device_get_port(this_device))
392 
393 /**
394  * This macro sets the remote device state handlers pointer and is set on
395  * entry to each device state.
396  */
397 #define scic_sds_remote_device_set_state_handlers(this_device, handlers) \
398    ((this_device)->state_handlers = (handlers))
399 
400 /**
401  * This macro returns the base sate machine object for the remote device.
402  */
403 #define scic_sds_remote_device_get_base_state_machine(this_device) \
404    (&(this_device)->parent.state_machine)
405 
406 /**
407  * This macro returns the remote device ready substate machine
408  */
409 #define scic_sds_remote_device_get_ready_substate_machine(this_device) \
410    (&(this_device)->ready_substate_machine)
411 
412 /**
413  * This macro returns the owning port of this device
414  */
415 #define scic_sds_remote_device_get_port(this_device) \
416    ((this_device)->owning_port)
417 
418 /**
419  * This macro returns the remote device sequence value
420  */
421 #define scic_sds_remote_device_get_sequence(this_device) \
422    ( \
423       scic_sds_remote_device_get_controller(this_device)->\
424          remote_device_sequence[(this_device)->rnc->remote_node_index] \
425    )
426 
427 /**
428  * This macro returns the controllers protocol engine group
429  */
430 #define scic_sds_remote_device_get_controller_peg(this_device) \
431    ( \
432       scic_sds_controller_get_protocol_engine_group( \
433          scic_sds_port_get_controller( \
434             scic_sds_remote_device_get_port(this_device) \
435          ) \
436       ) \
437    )
438 
439 /**
440  * This macro returns the port index for the devices owning port
441  */
442 #define scic_sds_remote_device_get_port_index(this_device) \
443    (scic_sds_port_get_index(scic_sds_remote_device_get_port(this_device)))
444 
445 /**
446  * This macro returns the remote node index for this device object
447  */
448 #define scic_sds_remote_device_get_index(this_device) \
449    ((this_device)->rnc->remote_node_index)
450 
451 /**
452  * This macro builds a remote device context for the SCU post request
453  * operation
454  */
455 #define scic_sds_remote_device_build_command_context(device, command) \
456    (   (command) \
457      | ((U32)(scic_sds_remote_device_get_controller_peg((device))) << SCU_CONTEXT_COMMAND_PROTOCOL_ENGINE_GROUP_SHIFT)\
458      | ((U32)(scic_sds_remote_device_get_port_index((device))) << SCU_CONTEXT_COMMAND_LOGICAL_PORT_SHIFT) \
459      | (scic_sds_remote_device_get_index((device))) \
460    )
461 
462 /**
463  * This macro makes the working request assingment for the remote device
464  * object. To clear the working request use this macro with a NULL request
465  * object.
466  */
467 #define scic_sds_remote_device_set_working_request(device, request) \
468    ((device)->working_request = (request))
469 
470 // ---------------------------------------------------------------------------
471 
472 U32 scic_sds_remote_device_get_min_timer_count(void);
473 
474 U32 scic_sds_remote_device_get_max_timer_count(void);
475 
476 SCI_STATUS scic_sds_remote_device_frame_handler(
477    SCIC_SDS_REMOTE_DEVICE_T *this_device,
478    U32                       frame_index
479 );
480 
481 SCI_STATUS scic_sds_remote_device_event_handler(
482    SCIC_SDS_REMOTE_DEVICE_T *this_device,
483    U32                       event_code
484 );
485 
486 SCI_STATUS scic_sds_remote_device_start_io(
487    struct SCIC_SDS_CONTROLLER *controller,
488    SCIC_SDS_REMOTE_DEVICE_T   *this_device,
489    struct SCIC_SDS_REQUEST    *io_request
490 );
491 
492 SCI_STATUS scic_sds_remote_device_complete_io(
493    struct SCIC_SDS_CONTROLLER *controller,
494    SCIC_SDS_REMOTE_DEVICE_T   *this_device,
495    struct SCIC_SDS_REQUEST    *io_request
496 );
497 
498 SCI_STATUS scic_sds_remote_device_resume(
499    SCIC_SDS_REMOTE_DEVICE_T *this_device
500 );
501 
502 SCI_STATUS scic_sds_remote_device_suspend(
503    SCIC_SDS_REMOTE_DEVICE_T *this_device,
504    U32                       suspend_type
505 );
506 
507 SCI_STATUS scic_sds_remote_device_start_task(
508    struct SCIC_SDS_CONTROLLER  *controller,
509    SCIC_SDS_REMOTE_DEVICE_T    *this_device,
510    struct SCIC_SDS_REQUEST     *io_request
511 );
512 
513 void scic_sds_remote_device_post_request(
514    SCIC_SDS_REMOTE_DEVICE_T * this_device,
515    U32                        request
516 );
517 
518 #if !defined(DISABLE_ATAPI)
519 BOOL scic_sds_remote_device_is_atapi(
520    SCIC_SDS_REMOTE_DEVICE_T    *this_device
521 );
522 #else // !defined(DISABLE_ATAPI)
523 #define scic_sds_remote_device_is_atapi(this_device) FALSE
524 #endif // !defined(DISABLE_ATAPI)
525 
526 // ---------------------------------------------------------------------------
527 
528 #ifdef SCI_LOGGING
529 void scic_sds_remote_device_initialize_state_logging(
530    SCIC_SDS_REMOTE_DEVICE_T *this_device
531 );
532 
533 void scic_sds_remote_device_deinitialize_state_logging(
534    SCIC_SDS_REMOTE_DEVICE_T *this_device
535 );
536 #else // SCI_LOGGING
537 #define scic_sds_remote_device_initialize_state_logging(x)
538 #define scic_sds_remote_device_deinitialize_state_logging(x)
539 #endif // SCI_LOGGING
540 
541 // ---------------------------------------------------------------------------
542 
543 void scic_sds_remote_device_start_request(
544    SCIC_SDS_REMOTE_DEVICE_T * this_device,
545    struct SCIC_SDS_REQUEST  * the_request,
546    SCI_STATUS                 status
547 );
548 
549 void scic_sds_remote_device_continue_request(
550    SCIC_SDS_REMOTE_DEVICE_T * this_device
551 );
552 
553 SCI_STATUS scic_sds_remote_device_default_start_handler(
554    SCI_BASE_REMOTE_DEVICE_T *this_device
555 );
556 
557 SCI_STATUS scic_sds_remote_device_default_stop_handler(
558    SCI_BASE_REMOTE_DEVICE_T *this_device
559 );
560 
561 SCI_STATUS scic_sds_remote_device_default_fail_handler(
562    SCI_BASE_REMOTE_DEVICE_T *this_device
563 );
564 
565 SCI_STATUS scic_sds_remote_device_default_destruct_handler(
566    SCI_BASE_REMOTE_DEVICE_T *this_device
567 );
568 
569 SCI_STATUS scic_sds_remote_device_default_reset_handler(
570    SCI_BASE_REMOTE_DEVICE_T *device
571 );
572 
573 SCI_STATUS scic_sds_remote_device_default_reset_complete_handler(
574    SCI_BASE_REMOTE_DEVICE_T *device
575 );
576 
577 SCI_STATUS scic_sds_remote_device_default_start_request_handler(
578    SCI_BASE_REMOTE_DEVICE_T *device,
579    SCI_BASE_REQUEST_T       *request
580 );
581 
582 SCI_STATUS scic_sds_remote_device_default_complete_request_handler(
583    SCI_BASE_REMOTE_DEVICE_T *device,
584    SCI_BASE_REQUEST_T       *request
585 );
586 
587 SCI_STATUS scic_sds_remote_device_default_continue_request_handler(
588    SCI_BASE_REMOTE_DEVICE_T *device,
589    SCI_BASE_REQUEST_T       *request
590 );
591 
592 SCI_STATUS scic_sds_remote_device_default_suspend_handler(
593    SCIC_SDS_REMOTE_DEVICE_T *this_device,
594    U32                       suspend_type
595 );
596 
597 SCI_STATUS scic_sds_remote_device_default_resume_handler(
598    SCIC_SDS_REMOTE_DEVICE_T *this_device
599 );
600 
601 SCI_STATUS  scic_sds_remote_device_default_event_handler(
602    SCIC_SDS_REMOTE_DEVICE_T *this_device,
603    U32                       event_code
604 );
605 
606 SCI_STATUS scic_sds_remote_device_default_frame_handler(
607    SCIC_SDS_REMOTE_DEVICE_T *this_device,
608    U32                       frame_index
609 );
610 
611 // ---------------------------------------------------------------------------
612 
613 SCI_STATUS scic_sds_remote_device_ready_state_stop_handler(
614    SCI_BASE_REMOTE_DEVICE_T *device
615 );
616 
617 SCI_STATUS scic_sds_remote_device_ready_state_reset_handler(
618    SCI_BASE_REMOTE_DEVICE_T *device
619 );
620 
621 SCI_STATUS scic_sds_remote_device_general_frame_handler(
622    SCIC_SDS_REMOTE_DEVICE_T *this_device,
623    U32                       frame_index
624 );
625 
626 SCI_STATUS scic_sds_remote_device_general_event_handler(
627    SCIC_SDS_REMOTE_DEVICE_T *this_device,
628    U32                       event_code
629 );
630 
631 SCI_STATUS scic_sds_ssp_remote_device_ready_suspended_substate_resume_handler(
632    SCIC_SDS_REMOTE_DEVICE_T *this_device
633 );
634 
635 // ---------------------------------------------------------------------------
636 
637 void scic_sds_remote_device_get_info_from_smp_discover_response(
638    SCIC_SDS_REMOTE_DEVICE_T    * this_device,
639    SMP_RESPONSE_DISCOVER_T     * discover_response
640 );
641 
642 #ifdef __cplusplus
643 }
644 #endif // __cplusplus
645 
646 #endif // _SCIC_SDS_REMOTE_DEVICE_H_
647