1fcf3ce44SJohn Forte /*
2fcf3ce44SJohn Forte  * CDDL HEADER START
3fcf3ce44SJohn Forte  *
4fcf3ce44SJohn Forte  * The contents of this file are subject to the terms of the
5fcf3ce44SJohn Forte  * Common Development and Distribution License (the "License").
6fcf3ce44SJohn Forte  * You may not use this file except in compliance with the License.
7fcf3ce44SJohn Forte  *
8fcf3ce44SJohn Forte  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9fcf3ce44SJohn Forte  * or http://www.opensolaris.org/os/licensing.
10fcf3ce44SJohn Forte  * See the License for the specific language governing permissions
11fcf3ce44SJohn Forte  * and limitations under the License.
12fcf3ce44SJohn Forte  *
13fcf3ce44SJohn Forte  * When distributing Covered Code, include this CDDL HEADER in each
14fcf3ce44SJohn Forte  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15fcf3ce44SJohn Forte  * If applicable, add the following below this CDDL HEADER, with the
16fcf3ce44SJohn Forte  * fields enclosed by brackets "[]" replaced with your own identifying
17fcf3ce44SJohn Forte  * information: Portions Copyright [yyyy] [name of copyright owner]
18fcf3ce44SJohn Forte  *
19fcf3ce44SJohn Forte  * CDDL HEADER END
20fcf3ce44SJohn Forte  */
21fcf3ce44SJohn Forte /*
22fcf3ce44SJohn Forte  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
23fcf3ce44SJohn Forte  * Use is subject to license terms.
24fcf3ce44SJohn Forte  */
25fcf3ce44SJohn Forte 
26fcf3ce44SJohn Forte #ifndef	_TARGETEVENTLISTENER_H
27fcf3ce44SJohn Forte #define	_TARGETEVENTLISTENER_H
28fcf3ce44SJohn Forte 
29fcf3ce44SJohn Forte 
30fcf3ce44SJohn Forte 
31fcf3ce44SJohn Forte #include "Listener.h"
32fcf3ce44SJohn Forte #include "HBAPort.h"
33fcf3ce44SJohn Forte #include <hbaapi.h>
34fcf3ce44SJohn Forte 
35fcf3ce44SJohn Forte /// Callback type
36fcf3ce44SJohn Forte typedef void (*TargetCallback)(
37fcf3ce44SJohn Forte 	void		*data,
38fcf3ce44SJohn Forte 	HBA_WWN		hbaPortWWN,
39fcf3ce44SJohn Forte 	HBA_WWN		discoveredPortWWN,
40fcf3ce44SJohn Forte 	HBA_UINT32	eventType);
41fcf3ce44SJohn Forte 
42fcf3ce44SJohn Forte /**
43fcf3ce44SJohn Forte  * @memo	    Encapsulates the callback routine for event dispatch
44*55fea89dSDan Cross  *
45fcf3ce44SJohn Forte  * @doc		    This class encapsulates the event callback routine
46fcf3ce44SJohn Forte  *		    registered in the public HBA API.  When dispatch
47fcf3ce44SJohn Forte  *		    is called, the stored callback routine will be called.
48fcf3ce44SJohn Forte  */
49fcf3ce44SJohn Forte class TargetEventListener: public Listener {
50fcf3ce44SJohn Forte public:
51fcf3ce44SJohn Forte 	TargetEventListener(HBAPort *port, TargetCallback myCallback,
52fcf3ce44SJohn Forte 	    void *data, uint64_t targetPortWWN, bool myFilter);
53fcf3ce44SJohn Forte 	virtual void dispatch(Event &event);
54fcf3ce44SJohn Forte private:
55fcf3ce44SJohn Forte 	TargetCallback  callback;
56fcf3ce44SJohn Forte 	bool	    filter;
57fcf3ce44SJohn Forte 	uint64_t	    targetPortWWN;
58fcf3ce44SJohn Forte 	HBAPort	    *port;
59fcf3ce44SJohn Forte };
60fcf3ce44SJohn Forte 
61fcf3ce44SJohn Forte 
62fcf3ce44SJohn Forte #endif /* _TARGETEVENTLISTENER_H */
63