xref: /freebsd/sys/dev/hyperv/include/hyperv.h (revision fafb1ee7bdc5d8a7d07cd03b2fb0bbb76f7a9d7c)
1 /*-
2  * Copyright (c) 2009-2012 Microsoft Corp.
3  * Copyright (c) 2012 NetApp Inc.
4  * Copyright (c) 2012 Citrix Inc.
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice unmodified, this list of conditions, and the following
12  *    disclaimer.
13  * 2. Redistributions in binary form must reproduce the above copyright
14  *    notice, this list of conditions and the following disclaimer in the
15  *    documentation and/or other materials provided with the distribution.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  *
28  * $FreeBSD$
29  */
30 
31 /**
32  * HyperV definitions for messages that are sent between instances of the
33  * Channel Management Library in separate partitions, or in some cases,
34  * back to itself.
35  */
36 
37 #ifndef __HYPERV_H__
38 #define __HYPERV_H__
39 
40 #include <sys/param.h>
41 #include <sys/mbuf.h>
42 #include <sys/queue.h>
43 #include <sys/malloc.h>
44 #include <sys/kthread.h>
45 #include <sys/taskqueue.h>
46 #include <sys/systm.h>
47 #include <sys/lock.h>
48 #include <sys/sema.h>
49 #include <sys/smp.h>
50 #include <sys/mutex.h>
51 #include <sys/bus.h>
52 #include <vm/vm.h>
53 #include <vm/vm_param.h>
54 #include <vm/pmap.h>
55 
56 #include <amd64/include/xen/synch_bitops.h>
57 #include <amd64/include/atomic.h>
58 
59 typedef uint8_t	hv_bool_uint8_t;
60 
61 #define HV_S_OK			0x00000000
62 #define HV_E_FAIL		0x80004005
63 #define HV_ERROR_NOT_SUPPORTED	0x80070032
64 #define HV_ERROR_MACHINE_LOCKED	0x800704F7
65 
66 /*
67  * VMBUS version is 32 bit, upper 16 bit for major_number and lower
68  * 16 bit for minor_number.
69  *
70  * 0.13  --  Windows Server 2008
71  * 1.1   --  Windows 7
72  * 2.4   --  Windows 8
73  * 3.0   --  Windows 8.1
74  */
75 #define HV_VMBUS_VERSION_WS2008		((0 << 16) | (13))
76 #define HV_VMBUS_VERSION_WIN7		((1 << 16) | (1))
77 #define HV_VMBUS_VERSION_WIN8		((2 << 16) | (4))
78 #define HV_VMBUS_VERSION_WIN8_1		((3 << 16) | (0))
79 
80 #define HV_VMBUS_VERSION_INVALID	-1
81 
82 #define HV_VMBUS_VERSION_CURRENT	HV_VMBUS_VERSION_WIN8_1
83 
84 /*
85  * Make maximum size of pipe payload of 16K
86  */
87 
88 #define HV_MAX_PIPE_DATA_PAYLOAD	(sizeof(BYTE) * 16384)
89 
90 /*
91  * Define pipe_mode values
92  */
93 
94 #define HV_VMBUS_PIPE_TYPE_BYTE		0x00000000
95 #define HV_VMBUS_PIPE_TYPE_MESSAGE	0x00000004
96 
97 /*
98  * The size of the user defined data buffer for non-pipe offers
99  */
100 
101 #define HV_MAX_USER_DEFINED_BYTES	120
102 
103 /*
104  *  The size of the user defined data buffer for pipe offers
105  */
106 
107 #define HV_MAX_PIPE_USER_DEFINED_BYTES	116
108 
109 
110 #define HV_MAX_PAGE_BUFFER_COUNT	32
111 #define HV_MAX_MULTIPAGE_BUFFER_COUNT	32
112 
113 #define HV_ALIGN_UP(value, align)					\
114 		(((value) & (align-1)) ?				\
115 		    (((value) + (align-1)) & ~(align-1) ) : (value))
116 
117 #define HV_ALIGN_DOWN(value, align) ( (value) & ~(align-1) )
118 
119 #define HV_NUM_PAGES_SPANNED(addr, len)					\
120 		((HV_ALIGN_UP(addr+len, PAGE_SIZE) -			\
121 		    HV_ALIGN_DOWN(addr, PAGE_SIZE)) >> PAGE_SHIFT )
122 
123 typedef struct hv_guid {
124 	 unsigned char data[16];
125 } __packed hv_guid;
126 
127 #define HV_NIC_GUID							\
128 	.data = {0x63, 0x51, 0x61, 0xF8, 0x3E, 0xDF, 0xc5, 0x46,	\
129 		0x91, 0x3F, 0xF2, 0xD2, 0xF9, 0x65, 0xED, 0x0E}
130 
131 #define HV_IDE_GUID							\
132 	.data = {0x32, 0x26, 0x41, 0x32, 0xcb, 0x86, 0xa2, 0x44,	\
133 		 0x9b, 0x5c, 0x50, 0xd1, 0x41, 0x73, 0x54, 0xf5}
134 
135 #define HV_SCSI_GUID							\
136 	.data = {0xd9, 0x63, 0x61, 0xba, 0xa1, 0x04, 0x29, 0x4d,	\
137 		 0xb6, 0x05, 0x72, 0xe2, 0xff, 0xb1, 0xdc, 0x7f}
138 
139 /*
140  * At the center of the Channel Management library is
141  * the Channel Offer. This struct contains the
142  * fundamental information about an offer.
143  */
144 
145 typedef struct hv_vmbus_channel_offer {
146 	hv_guid		interface_type;
147 	hv_guid		interface_instance;
148 	uint64_t	interrupt_latency_in_100ns_units;
149 	uint32_t	interface_revision;
150 	uint32_t	server_context_area_size; /* in bytes */
151 	uint16_t	channel_flags;
152 	uint16_t	mmio_megabytes;		  /* in bytes * 1024 * 1024 */
153 	union
154 	{
155         /*
156          * Non-pipes: The user has HV_MAX_USER_DEFINED_BYTES bytes.
157          */
158 		struct {
159 			uint8_t	user_defined[HV_MAX_USER_DEFINED_BYTES];
160 		} __packed standard;
161 
162         /*
163          * Pipes: The following structure is an integrated pipe protocol, which
164          *        is implemented on top of standard user-defined data. pipe
165          *        clients  have HV_MAX_PIPE_USER_DEFINED_BYTES left for their
166          *        own use.
167          */
168 		struct {
169 			uint32_t	pipe_mode;
170 			uint8_t	user_defined[HV_MAX_PIPE_USER_DEFINED_BYTES];
171 		} __packed pipe;
172 	} u;
173 
174 	/*
175 	 * Sub_channel_index, newly added in Win8.
176 	 */
177 	uint16_t	sub_channel_index;
178 	uint16_t	padding;
179 
180 } __packed hv_vmbus_channel_offer;
181 
182 typedef uint32_t hv_gpadl_handle;
183 
184 typedef struct {
185 	uint16_t type;
186 	uint16_t data_offset8;
187 	uint16_t length8;
188 	uint16_t flags;
189 	uint64_t transaction_id;
190 } __packed hv_vm_packet_descriptor;
191 
192 typedef uint32_t hv_previous_packet_offset;
193 
194 typedef struct {
195 	hv_previous_packet_offset	previous_packet_start_offset;
196 	hv_vm_packet_descriptor		descriptor;
197 } __packed hv_vm_packet_header;
198 
199 typedef struct {
200 	uint32_t byte_count;
201 	uint32_t byte_offset;
202 } __packed hv_vm_transfer_page;
203 
204 typedef struct {
205 	hv_vm_packet_descriptor	d;
206 	uint16_t		transfer_page_set_id;
207 	hv_bool_uint8_t		sender_owns_set;
208 	uint8_t			reserved;
209 	uint32_t		range_count;
210 	hv_vm_transfer_page	ranges[1];
211 } __packed hv_vm_transfer_page_packet_header;
212 
213 typedef struct {
214 	hv_vm_packet_descriptor	d;
215 	uint32_t		gpadl;
216 	uint32_t		reserved;
217 } __packed hv_vm_gpadl_packet_header;
218 
219 typedef struct {
220 	hv_vm_packet_descriptor	d;
221 	uint32_t		gpadl;
222 	uint16_t		transfer_page_set_id;
223 	uint16_t		reserved;
224 } __packed hv_vm_add_remove_transfer_page_set;
225 
226 /*
227  * This structure defines a range in guest
228  * physical space that can be made
229  * to look virtually contiguous.
230  */
231 
232 typedef struct {
233 	uint32_t byte_count;
234 	uint32_t byte_offset;
235 	uint64_t pfn_array[0];
236 } __packed hv_gpa_range;
237 
238 /*
239  * This is the format for an Establish Gpadl packet, which contains a handle
240  * by which this GPADL will be known and a set of GPA ranges associated with
241  * it.  This can be converted to a MDL by the guest OS.  If there are multiple
242  * GPA ranges, then the resulting MDL will be "chained," representing multiple
243  * VA ranges.
244  */
245 
246 typedef struct {
247 	hv_vm_packet_descriptor	d;
248 	uint32_t		gpadl;
249 	uint32_t		range_count;
250 	hv_gpa_range		range[1];
251 } __packed hv_vm_establish_gpadl;
252 
253 /*
254  * This is the format for a Teardown Gpadl packet, which indicates that the
255  * GPADL handle in the Establish Gpadl packet will never be referenced again.
256  */
257 
258 typedef struct {
259 	hv_vm_packet_descriptor	d;
260 	uint32_t		gpadl;
261 				/* for alignment to a 8-byte boundary */
262 	uint32_t		reserved;
263 } __packed hv_vm_teardown_gpadl;
264 
265 /*
266  * This is the format for a GPA-Direct packet, which contains a set of GPA
267  * ranges, in addition to commands and/or data.
268  */
269 
270 typedef struct {
271 	hv_vm_packet_descriptor	d;
272 	uint32_t		reserved;
273 	uint32_t		range_count;
274 	hv_gpa_range		range[1];
275 } __packed hv_vm_data_gpa_direct;
276 
277 /*
278  * This is the format for a Additional data Packet.
279  */
280 typedef struct {
281 	hv_vm_packet_descriptor	d;
282 	uint64_t		total_bytes;
283 	uint32_t		byte_offset;
284 	uint32_t		byte_count;
285 	uint8_t			data[1];
286 } __packed hv_vm_additional_data;
287 
288 typedef union {
289 	hv_vm_packet_descriptor             simple_header;
290 	hv_vm_transfer_page_packet_header   transfer_page_header;
291 	hv_vm_gpadl_packet_header           gpadl_header;
292 	hv_vm_add_remove_transfer_page_set  add_remove_transfer_page_header;
293 	hv_vm_establish_gpadl               establish_gpadl_header;
294 	hv_vm_teardown_gpadl                teardown_gpadl_header;
295 	hv_vm_data_gpa_direct               data_gpa_direct_header;
296 } __packed hv_vm_packet_largest_possible_header;
297 
298 typedef enum {
299 	HV_VMBUS_PACKET_TYPE_INVALID				= 0x0,
300 	HV_VMBUS_PACKET_TYPES_SYNCH				= 0x1,
301 	HV_VMBUS_PACKET_TYPE_ADD_TRANSFER_PAGE_SET		= 0x2,
302 	HV_VMBUS_PACKET_TYPE_REMOVE_TRANSFER_PAGE_SET		= 0x3,
303 	HV_VMBUS_PACKET_TYPE_ESTABLISH_GPADL			= 0x4,
304 	HV_VMBUS_PACKET_TYPE_TEAR_DOWN_GPADL			= 0x5,
305 	HV_VMBUS_PACKET_TYPE_DATA_IN_BAND			= 0x6,
306 	HV_VMBUS_PACKET_TYPE_DATA_USING_TRANSFER_PAGES		= 0x7,
307 	HV_VMBUS_PACKET_TYPE_DATA_USING_GPADL			= 0x8,
308 	HV_VMBUS_PACKET_TYPE_DATA_USING_GPA_DIRECT		= 0x9,
309 	HV_VMBUS_PACKET_TYPE_CANCEL_REQUEST			= 0xa,
310 	HV_VMBUS_PACKET_TYPE_COMPLETION				= 0xb,
311 	HV_VMBUS_PACKET_TYPE_DATA_USING_ADDITIONAL_PACKETS	= 0xc,
312 	HV_VMBUS_PACKET_TYPE_ADDITIONAL_DATA = 0xd
313 } hv_vmbus_packet_type;
314 
315 #define HV_VMBUS_DATA_PACKET_FLAG_COMPLETION_REQUESTED    1
316 
317 /*
318  * Version 1 messages
319  */
320 typedef enum {
321 	HV_CHANNEL_MESSAGE_INVALID			= 0,
322 	HV_CHANNEL_MESSAGE_OFFER_CHANNEL		= 1,
323 	HV_CHANNEL_MESSAGE_RESCIND_CHANNEL_OFFER	= 2,
324 	HV_CHANNEL_MESSAGE_REQUEST_OFFERS		= 3,
325 	HV_CHANNEL_MESSAGE_ALL_OFFERS_DELIVERED		= 4,
326 	HV_CHANNEL_MESSAGE_OPEN_CHANNEL			= 5,
327 	HV_CHANNEL_MESSAGE_OPEN_CHANNEL_RESULT		= 6,
328 	HV_CHANNEL_MESSAGE_CLOSE_CHANNEL		= 7,
329 	HV_CHANNEL_MESSAGEL_GPADL_HEADER		= 8,
330 	HV_CHANNEL_MESSAGE_GPADL_BODY			= 9,
331 	HV_CHANNEL_MESSAGE_GPADL_CREATED		= 10,
332 	HV_CHANNEL_MESSAGE_GPADL_TEARDOWN		= 11,
333 	HV_CHANNEL_MESSAGE_GPADL_TORNDOWN		= 12,
334 	HV_CHANNEL_MESSAGE_REL_ID_RELEASED		= 13,
335 	HV_CHANNEL_MESSAGE_INITIATED_CONTACT		= 14,
336 	HV_CHANNEL_MESSAGE_VERSION_RESPONSE		= 15,
337 	HV_CHANNEL_MESSAGE_UNLOAD			= 16,
338 
339 #ifdef	HV_VMBUS_FEATURE_PARENT_OR_PEER_MEMORY_MAPPED_INTO_A_CHILD
340 	HV_CHANNEL_MESSAGE_VIEW_RANGE_ADD		= 17,
341 	HV_CHANNEL_MESSAGE_VIEW_RANGE_REMOVE		= 18,
342 #endif
343 	HV_CHANNEL_MESSAGE_COUNT
344 } hv_vmbus_channel_msg_type;
345 
346 typedef struct {
347 	hv_vmbus_channel_msg_type	message_type;
348 	uint32_t			padding;
349 } __packed hv_vmbus_channel_msg_header;
350 
351 /*
352  * Query VMBus Version parameters
353  */
354 typedef struct {
355 	hv_vmbus_channel_msg_header	header;
356 	uint32_t			version;
357 } __packed hv_vmbus_channel_query_vmbus_version;
358 
359 /*
360  * VMBus Version Supported parameters
361  */
362 typedef struct {
363 	hv_vmbus_channel_msg_header	header;
364 	hv_bool_uint8_t			version_supported;
365 } __packed hv_vmbus_channel_version_supported;
366 
367 /*
368  * Channel Offer parameters
369  */
370 typedef struct {
371 	hv_vmbus_channel_msg_header	header;
372 	hv_vmbus_channel_offer		offer;
373 	uint32_t			child_rel_id;
374 	uint8_t				monitor_id;
375 	/*
376 	 * This field has been split into a bit field on Win7
377 	 * and higher.
378 	 */
379 	uint8_t				monitor_allocated:1;
380 	uint8_t				reserved:7;
381 	/*
382 	 * Following fields were added in win7 and higher.
383 	 * Make sure to check the version before accessing these fields.
384 	 *
385 	 * If "is_dedicated_interrupt" is set, we must not set the
386 	 * associated bit in the channel bitmap while sending the
387 	 * interrupt to the host.
388 	 *
389 	 * connection_id is used in signaling the host.
390 	 */
391 	uint16_t			is_dedicated_interrupt:1;
392 	uint16_t			reserved1:15;
393 	uint32_t			connection_id;
394 } __packed hv_vmbus_channel_offer_channel;
395 
396 /*
397  * Rescind Offer parameters
398  */
399 typedef struct
400 {
401     hv_vmbus_channel_msg_header	header;
402     uint32_t			child_rel_id;
403 } __packed hv_vmbus_channel_rescind_offer;
404 
405 
406 /*
407  * Request Offer -- no parameters, SynIC message contains the partition ID
408  *
409  * Set Snoop -- no parameters, SynIC message contains the partition ID
410  *
411  * Clear Snoop -- no parameters, SynIC message contains the partition ID
412  *
413  * All Offers Delivered -- no parameters, SynIC message contains the
414  * partition ID
415  *
416  * Flush Client -- no parameters, SynIC message contains the partition ID
417  */
418 
419 
420 /*
421  * Open Channel parameters
422  */
423 typedef struct
424 {
425     hv_vmbus_channel_msg_header header;
426 
427     /*
428      * Identifies the specific VMBus channel that is being opened.
429      */
430     uint32_t		child_rel_id;
431 
432     /*
433      * ID making a particular open request at a channel offer unique.
434      */
435     uint32_t		open_id;
436 
437     /*
438      * GPADL for the channel's ring buffer.
439      */
440     hv_gpadl_handle	ring_buffer_gpadl_handle;
441 
442     /*
443      * Before win8, all incoming channel interrupts are only
444      * delivered on cpu 0. Setting this value to 0 would
445      * preserve the earlier behavior.
446      */
447     uint32_t		target_vcpu;
448 
449     /*
450      * The upstream ring buffer begins at offset zero in the memory described
451      * by ring_buffer_gpadl_handle. The downstream ring buffer follows it at
452      * this offset (in pages).
453      */
454     uint32_t		downstream_ring_buffer_page_offset;
455 
456     /*
457      * User-specific data to be passed along to the server endpoint.
458      */
459     uint8_t		user_data[HV_MAX_USER_DEFINED_BYTES];
460 
461 } __packed hv_vmbus_channel_open_channel;
462 
463 typedef uint32_t hv_nt_status;
464 
465 /*
466  * Open Channel Result parameters
467  */
468 typedef struct
469 {
470 	hv_vmbus_channel_msg_header	header;
471 	uint32_t			child_rel_id;
472 	uint32_t			open_id;
473 	hv_nt_status			status;
474 } __packed hv_vmbus_channel_open_result;
475 
476 /*
477  * Close channel parameters
478  */
479 typedef struct
480 {
481 	hv_vmbus_channel_msg_header	header;
482 	uint32_t			child_rel_id;
483 } __packed hv_vmbus_channel_close_channel;
484 
485 /*
486  * Channel Message GPADL
487  */
488 #define HV_GPADL_TYPE_RING_BUFFER	1
489 #define HV_GPADL_TYPE_SERVER_SAVE_AREA	2
490 #define HV_GPADL_TYPE_TRANSACTION	8
491 
492 /*
493  * The number of PFNs in a GPADL message is defined by the number of pages
494  * that would be spanned by byte_count and byte_offset.  If the implied number
495  * of PFNs won't fit in this packet, there will be a follow-up packet that
496  * contains more
497  */
498 
499 typedef struct {
500 	hv_vmbus_channel_msg_header	header;
501 	uint32_t			child_rel_id;
502 	uint32_t			gpadl;
503 	uint16_t			range_buf_len;
504 	uint16_t			range_count;
505 	hv_gpa_range			range[0];
506 } __packed hv_vmbus_channel_gpadl_header;
507 
508 /*
509  * This is the follow-up packet that contains more PFNs
510  */
511 typedef struct {
512 	hv_vmbus_channel_msg_header	header;
513 	uint32_t			message_number;
514 	uint32_t 			gpadl;
515 	uint64_t 			pfn[0];
516 } __packed hv_vmbus_channel_gpadl_body;
517 
518 typedef struct {
519 	hv_vmbus_channel_msg_header	header;
520 	uint32_t			child_rel_id;
521 	uint32_t			gpadl;
522 	uint32_t			creation_status;
523 } __packed hv_vmbus_channel_gpadl_created;
524 
525 typedef struct {
526 	hv_vmbus_channel_msg_header	header;
527 	uint32_t			child_rel_id;
528 	uint32_t			gpadl;
529 } __packed hv_vmbus_channel_gpadl_teardown;
530 
531 typedef struct {
532 	hv_vmbus_channel_msg_header	header;
533 	uint32_t			gpadl;
534 } __packed hv_vmbus_channel_gpadl_torndown;
535 
536 typedef struct {
537 	hv_vmbus_channel_msg_header	header;
538 	uint32_t			child_rel_id;
539 } __packed hv_vmbus_channel_relid_released;
540 
541 typedef struct {
542 	hv_vmbus_channel_msg_header	header;
543 	uint32_t			vmbus_version_requested;
544 	uint32_t			padding2;
545 	uint64_t			interrupt_page;
546 	uint64_t			monitor_page_1;
547 	uint64_t			monitor_page_2;
548 } __packed hv_vmbus_channel_initiate_contact;
549 
550 typedef struct {
551 	hv_vmbus_channel_msg_header header;
552 	hv_bool_uint8_t		version_supported;
553 } __packed hv_vmbus_channel_version_response;
554 
555 typedef hv_vmbus_channel_msg_header hv_vmbus_channel_unload;
556 
557 #define HW_MACADDR_LEN	6
558 
559 /*
560  * Fixme:  Added to quiet "typeof" errors involving hv_vmbus.h when
561  * the including C file was compiled with "-std=c99".
562  */
563 #ifndef typeof
564 #define typeof __typeof
565 #endif
566 
567 #ifndef NULL
568 #define NULL  (void *)0
569 #endif
570 
571 typedef void *hv_vmbus_handle;
572 
573 #ifndef CONTAINING_RECORD
574 #define CONTAINING_RECORD(address, type, field) ((type *)(	\
575 		(uint8_t *)(address) -				\
576 		(uint8_t *)(&((type *)0)->field)))
577 #endif /* CONTAINING_RECORD */
578 
579 
580 #define container_of(ptr, type, member) ({				\
581 		__typeof__( ((type *)0)->member ) *__mptr = (ptr);	\
582 		(type *)( (char *)__mptr - offsetof(type,member) );})
583 
584 enum {
585 	HV_VMBUS_IVAR_TYPE,
586 	HV_VMBUS_IVAR_INSTANCE,
587 	HV_VMBUS_IVAR_NODE,
588 	HV_VMBUS_IVAR_DEVCTX
589 };
590 
591 #define HV_VMBUS_ACCESSOR(var, ivar, type) \
592 		__BUS_ACCESSOR(vmbus, var, HV_VMBUS, ivar, type)
593 
594 HV_VMBUS_ACCESSOR(type, TYPE,  const char *)
595 HV_VMBUS_ACCESSOR(devctx, DEVCTX,  struct hv_device *)
596 
597 
598 /*
599  * Common defines for Hyper-V ICs
600  */
601 #define HV_ICMSGTYPE_NEGOTIATE		0
602 #define HV_ICMSGTYPE_HEARTBEAT		1
603 #define HV_ICMSGTYPE_KVPEXCHANGE	2
604 #define HV_ICMSGTYPE_SHUTDOWN		3
605 #define HV_ICMSGTYPE_TIMESYNC		4
606 #define HV_ICMSGTYPE_VSS		5
607 
608 #define HV_ICMSGHDRFLAG_TRANSACTION	1
609 #define HV_ICMSGHDRFLAG_REQUEST		2
610 #define HV_ICMSGHDRFLAG_RESPONSE	4
611 
612 typedef struct hv_vmbus_pipe_hdr {
613 	uint32_t flags;
614 	uint32_t msgsize;
615 } __packed hv_vmbus_pipe_hdr;
616 
617 typedef struct hv_vmbus_ic_version {
618 	uint16_t major;
619 	uint16_t minor;
620 } __packed hv_vmbus_ic_version;
621 
622 typedef struct hv_vmbus_icmsg_hdr {
623 	hv_vmbus_ic_version	icverframe;
624 	uint16_t		icmsgtype;
625 	hv_vmbus_ic_version	icvermsg;
626 	uint16_t		icmsgsize;
627 	uint32_t		status;
628 	uint8_t			ictransaction_id;
629 	uint8_t			icflags;
630 	uint8_t			reserved[2];
631 } __packed hv_vmbus_icmsg_hdr;
632 
633 typedef struct hv_vmbus_icmsg_negotiate {
634 	uint16_t		icframe_vercnt;
635 	uint16_t		icmsg_vercnt;
636 	uint32_t		reserved;
637 	hv_vmbus_ic_version	icversion_data[1]; /* any size array */
638 } __packed hv_vmbus_icmsg_negotiate;
639 
640 typedef struct hv_vmbus_shutdown_msg_data {
641 	uint32_t		reason_code;
642 	uint32_t		timeout_seconds;
643 	uint32_t 		flags;
644 	uint8_t			display_message[2048];
645 } __packed hv_vmbus_shutdown_msg_data;
646 
647 typedef struct hv_vmbus_heartbeat_msg_data {
648 	uint64_t 		seq_num;
649 	uint32_t 		reserved[8];
650 } __packed hv_vmbus_heartbeat_msg_data;
651 
652 typedef struct {
653 	/*
654 	 * offset in bytes from the start of ring data below
655 	 */
656 	volatile uint32_t       write_index;
657 	/*
658 	 * offset in bytes from the start of ring data below
659 	 */
660 	volatile uint32_t       read_index;
661 	/*
662 	 * NOTE: The interrupt_mask field is used only for channels, but
663 	 * vmbus connection also uses this data structure
664 	 */
665 	volatile uint32_t       interrupt_mask;
666 	/* pad it to PAGE_SIZE so that data starts on a page */
667 	uint8_t                 reserved[4084];
668 
669 	/*
670 	 * WARNING: Ring data starts here + ring_data_start_offset
671 	 *  !!! DO NOT place any fields below this !!!
672 	 */
673 	uint8_t			buffer[0];	/* doubles as interrupt mask */
674 } __packed hv_vmbus_ring_buffer;
675 
676 typedef struct {
677 	int		length;
678 	int		offset;
679 	uint64_t	pfn;
680 } __packed hv_vmbus_page_buffer;
681 
682 typedef struct {
683 	int		length;
684 	int		offset;
685 	uint64_t	pfn_array[HV_MAX_MULTIPAGE_BUFFER_COUNT];
686 } __packed hv_vmbus_multipage_buffer;
687 
688 typedef struct {
689 	hv_vmbus_ring_buffer*	ring_buffer;
690 	uint32_t		ring_size;	/* Include the shared header */
691 	struct mtx		ring_lock;
692 	uint32_t		ring_data_size;	/* ring_size */
693 	uint32_t		ring_data_start_offset;
694 } hv_vmbus_ring_buffer_info;
695 
696 typedef void (*hv_vmbus_pfn_channel_callback)(void *context);
697 typedef void (*hv_vmbus_sc_creation_callback)(void *context);
698 
699 typedef enum {
700 	HV_CHANNEL_OFFER_STATE,
701 	HV_CHANNEL_OPENING_STATE,
702 	HV_CHANNEL_OPEN_STATE,
703 	HV_CHANNEL_OPENED_STATE,
704 	HV_CHANNEL_CLOSING_NONDESTRUCTIVE_STATE,
705 } hv_vmbus_channel_state;
706 
707 /*
708  *  Connection identifier type
709  */
710 typedef union {
711 	uint32_t		as_uint32_t;
712 	struct {
713 		uint32_t	id:24;
714 		uint32_t	reserved:8;
715 	} u;
716 
717 } __packed hv_vmbus_connection_id;
718 
719 /*
720  * Definition of the hv_vmbus_signal_event hypercall input structure
721  */
722 typedef struct {
723 	hv_vmbus_connection_id	connection_id;
724 	uint16_t		flag_number;
725 	uint16_t		rsvd_z;
726 } __packed hv_vmbus_input_signal_event;
727 
728 typedef struct {
729 	uint64_t			align8;
730 	hv_vmbus_input_signal_event	event;
731 } __packed hv_vmbus_input_signal_event_buffer;
732 
733 typedef struct hv_vmbus_channel {
734 	TAILQ_ENTRY(hv_vmbus_channel)	list_entry;
735 	struct hv_device*		device;
736 	hv_vmbus_channel_state		state;
737 	hv_vmbus_channel_offer_channel	offer_msg;
738 	/*
739 	 * These are based on the offer_msg.monitor_id.
740 	 * Save it here for easy access.
741 	 */
742 	uint8_t				monitor_group;
743 	uint8_t				monitor_bit;
744 
745 	uint32_t			ring_buffer_gpadl_handle;
746 	/*
747 	 * Allocated memory for ring buffer
748 	 */
749 	void*				ring_buffer_pages;
750 	unsigned long			ring_buffer_size;
751 	uint32_t			ring_buffer_page_count;
752 	/*
753 	 * send to parent
754 	 */
755 	hv_vmbus_ring_buffer_info	outbound;
756 	/*
757 	 * receive from parent
758 	 */
759 	hv_vmbus_ring_buffer_info	inbound;
760 
761 	struct mtx			inbound_lock;
762 
763 	hv_vmbus_pfn_channel_callback	on_channel_callback;
764 	void*				channel_callback_context;
765 
766 	/*
767 	 * If batched_reading is set to "true", mask the interrupt
768 	 * and read until the channel is empty.
769 	 * If batched_reading is set to "false", the channel is not
770 	 * going to perform batched reading.
771 	 *
772 	 * Batched reading is enabled by default; specific
773 	 * drivers that don't want this behavior can turn it off.
774 	 */
775 	boolean_t			batched_reading;
776 
777 	boolean_t			is_dedicated_interrupt;
778 
779 	/*
780 	 * Used as an input param for HV_CALL_SIGNAL_EVENT hypercall.
781 	 */
782 	hv_vmbus_input_signal_event_buffer	signal_event_buffer;
783 	/*
784 	 * 8-bytes aligned of the buffer above
785 	 */
786 	hv_vmbus_input_signal_event	*signal_event_param;
787 
788 	/*
789 	 * From Win8, this field specifies the target virtual process
790 	 * on which to deliver the interupt from the host to guest.
791 	 * Before Win8, all channel interrupts would only be
792 	 * delivered on cpu 0. Setting this value to 0 would preserve
793 	 * the earlier behavior.
794 	 */
795 	uint32_t			target_vcpu;
796 	/* The corresponding CPUID in the guest */
797 	uint32_t			target_cpu;
798 
799 	/*
800 	 * Support for multi-channels.
801 	 * The initial offer is considered the primary channel and this
802 	 * offer message will indicate if the host supports multi-channels.
803 	 * The guest is free to ask for multi-channels to be offerred and can
804 	 * open these multi-channels as a normal "primary" channel. However,
805 	 * all multi-channels will have the same type and instance guids as the
806 	 * primary channel. Requests sent on a given channel will result in a
807 	 * response on the same channel.
808 	 */
809 
810 	/*
811 	 * Multi-channel creation callback. This callback will be called in
812 	 * process context when a Multi-channel offer is received from the host.
813 	 * The guest can open the Multi-channel in the context of this callback.
814 	 */
815 	hv_vmbus_sc_creation_callback	sc_creation_callback;
816 
817 	struct mtx			sc_lock;
818 
819 	/*
820 	 * Link list of all the multi-channels if this is a primary channel
821 	 */
822 	TAILQ_HEAD(, hv_vmbus_channel)	sc_list_anchor;
823 	TAILQ_ENTRY(hv_vmbus_channel)	sc_list_entry;
824 
825 	/*
826 	 * The primary channel this sub-channle belongs to.
827 	 * This will be NULL for the primary channel.
828 	 */
829 	struct hv_vmbus_channel		*primary_channel;
830 	/*
831 	 * Support per channel state for use by vmbus drivers.
832 	 */
833 	void				*per_channel_state;
834 } hv_vmbus_channel;
835 
836 static inline void
837 hv_set_channel_read_state(hv_vmbus_channel* channel, boolean_t state)
838 {
839 	channel->batched_reading = state;
840 }
841 
842 typedef struct hv_device {
843 	hv_guid		    class_id;
844 	hv_guid		    device_id;
845 	device_t	    device;
846 	hv_vmbus_channel*   channel;
847 } hv_device;
848 
849 
850 
851 int		hv_vmbus_channel_recv_packet(
852 				hv_vmbus_channel*	channel,
853 				void*			buffer,
854 				uint32_t		buffer_len,
855 				uint32_t*		buffer_actual_len,
856 				uint64_t*		request_id);
857 
858 int		hv_vmbus_channel_recv_packet_raw(
859 				hv_vmbus_channel*	channel,
860 				void*			buffer,
861 				uint32_t		buffer_len,
862 				uint32_t*		buffer_actual_len,
863 				uint64_t*		request_id);
864 
865 int		hv_vmbus_channel_open(
866 				hv_vmbus_channel*	channel,
867 				uint32_t		send_ring_buffer_size,
868 				uint32_t		recv_ring_buffer_size,
869 				void*			user_data,
870 				uint32_t		user_data_len,
871 				hv_vmbus_pfn_channel_callback
872 							pfn_on_channel_callback,
873 				void*			context);
874 
875 void		hv_vmbus_channel_close(hv_vmbus_channel *channel);
876 
877 int		hv_vmbus_channel_send_packet(
878 				hv_vmbus_channel*	channel,
879 				void*			buffer,
880 				uint32_t		buffer_len,
881 				uint64_t		request_id,
882 				hv_vmbus_packet_type	type,
883 				uint32_t		flags);
884 
885 int		hv_vmbus_channel_send_packet_pagebuffer(
886 				hv_vmbus_channel*	channel,
887 				hv_vmbus_page_buffer	page_buffers[],
888 				uint32_t		page_count,
889 				void*			buffer,
890 				uint32_t		buffer_len,
891 				uint64_t		request_id);
892 
893 int		hv_vmbus_channel_send_packet_multipagebuffer(
894 				hv_vmbus_channel*	    channel,
895 				hv_vmbus_multipage_buffer*  multi_page_buffer,
896 				void*			    buffer,
897 				uint32_t		    buffer_len,
898 				uint64_t		    request_id);
899 
900 int		hv_vmbus_channel_establish_gpadl(
901 				hv_vmbus_channel*	channel,
902 				/* must be phys and virt contiguous */
903 				void*			contig_buffer,
904 				/*  page-size multiple	*/
905 				uint32_t		size,
906 				uint32_t*		gpadl_handle);
907 
908 int		hv_vmbus_channel_teardown_gpdal(
909 				hv_vmbus_channel*	channel,
910 				uint32_t		gpadl_handle);
911 
912 struct hv_vmbus_channel* vmbus_select_outgoing_channel(struct hv_vmbus_channel *promary);
913 
914 /*
915  * Work abstraction defines
916  */
917 typedef struct hv_work_queue {
918 	struct taskqueue*	queue;
919 	struct proc*		proc;
920 	struct sema*		work_sema;
921 } hv_work_queue;
922 
923 typedef struct hv_work_item {
924 	struct task	work;
925 	void		(*callback)(void *);
926 	void*		context;
927 	hv_work_queue*	wq;
928 } hv_work_item;
929 
930 struct hv_work_queue*	hv_work_queue_create(char* name);
931 
932 void			hv_work_queue_close(struct hv_work_queue* wq);
933 
934 int			hv_queue_work_item(
935 				hv_work_queue*	wq,
936 				void		(*callback)(void *),
937 				void*		context);
938 /**
939  * @brief Get physical address from virtual
940  */
941 static inline unsigned long
942 hv_get_phys_addr(void *virt)
943 {
944 	unsigned long ret;
945 	ret = (vtophys(virt) | ((vm_offset_t) virt & PAGE_MASK));
946 	return (ret);
947 }
948 
949 
950 /**
951  * KVP related structures
952  *
953  */
954 typedef struct hv_vmbus_service {
955         hv_guid       guid;             /* Hyper-V GUID */
956         char          *name;            /* name of service */
957         boolean_t     enabled;          /* service enabled */
958         hv_work_queue *work_queue;      /* background work queue */
959 
960         /*
961          * function to initialize service
962          */
963         int (*init)(struct hv_vmbus_service *);
964 
965         /*
966          * function to process Hyper-V messages
967          */
968         void (*callback)(void *);
969 } hv_vmbus_service;
970 
971 extern uint8_t* receive_buffer[];
972 extern hv_vmbus_service service_table[];
973 extern uint32_t hv_vmbus_protocal_version;
974 
975 void hv_kvp_callback(void *context);
976 int hv_kvp_init(hv_vmbus_service *serv);
977 void hv_kvp_deinit(void);
978 
979 #endif  /* __HYPERV_H__ */
980 
981