2017-11-07 14:58:47 +01:00
// SPDX-License-Identifier: GPL-2.0
2017-06-30 15:43:03 -04:00
/*
* Copyright ( C ) 2010 - 2015 UNISYS CORPORATION
2014-03-04 07:58:07 -06:00
* All rights reserved .
*/
# ifndef __VBUSCHANNEL_H__
# define __VBUSCHANNEL_H__
2017-06-30 15:43:03 -04:00
/*
* The vbus channel is the channel area provided via the BUS_CREATE controlvm
* message for each virtual bus . This channel area is provided to both server
* and client ends of the bus . The channel header area is initialized by
* the server , and the remaining information is filled in by the client .
* We currently use this for the client to provide various information about
* the client devices and client drivers for the server end to see .
2014-03-04 07:58:07 -06:00
*/
2017-06-30 15:43:03 -04:00
2014-05-06 09:58:23 -04:00
# include <linux/uuid.h>
2017-12-07 12:11:07 -05:00
# include <linux/visorbus.h>
2014-03-04 07:58:07 -06:00
/* {193b331b-c58f-11da-95a9-00e08161165f} */
2017-08-22 13:26:54 -04:00
# define VISOR_VBUS_CHANNEL_GUID \
GUID_INIT ( 0x193b331b , 0xc58f , 0x11da , \
0x95 , 0xa9 , 0x0 , 0xe0 , 0x81 , 0x61 , 0x16 , 0x5f )
2014-03-04 07:58:07 -06:00
2017-06-30 15:43:03 -04:00
/*
* Must increment this whenever you insert or delete fields within this channel
2015-11-17 13:35:00 -05:00
* struct . Also increment whenever you change the meaning of fields within this
* channel struct so as to break pre - existing software . Note that you can
* usually add fields to the END of the channel struct withOUT needing to
* increment this .
*/
2017-05-19 16:17:44 -04:00
# define VISOR_VBUS_CHANNEL_VERSIONID 1
2014-03-04 07:58:07 -06:00
2017-08-22 13:26:55 -04:00
/*
* struct visor_vbus_deviceinfo
2017-06-30 15:43:03 -04:00
* @ devtype : Short string identifying the device type .
* @ drvname : Driver . sys file name .
* @ infostrs : Kernel vversion .
* @ reserved : Pad size to 256 bytes .
*
2017-09-27 13:14:47 -04:00
* An array of this struct is present in the channel area for each vbus . It is
* filled in by the client side to provide info about the device and driver from
* the client ' s perspective .
2016-09-02 16:41:39 -04:00
*/
2017-05-19 16:17:45 -04:00
struct visor_vbus_deviceinfo {
2017-06-30 15:43:03 -04:00
u8 devtype [ 16 ] ;
u8 drvname [ 16 ] ;
u8 infostrs [ 96 ] ;
u8 reserved [ 128 ] ;
2017-03-17 11:27:16 -04:00
} __packed ;
2016-09-02 16:41:39 -04:00
2017-06-30 15:43:03 -04:00
/*
* struct visor_vbus_headerinfo
* @ struct_bytes : Size of this struct in bytes .
* @ device_info_struct_bytes : Size of VISOR_VBUS_DEVICEINFO .
* @ dev_info_count : Num of items in DevInfo member . This is the
* allocated size .
* @ chp_info_offset : Byte offset from beginning of this struct to the
* ChpInfo struct .
* @ bus_info_offset : Byte offset from beginning of this struct to the
* BusInfo struct .
* @ dev_info_offset : Byte offset from beginning of this struct to the
* DevInfo array .
2017-09-27 13:14:47 -04:00
* @ reserved : Natural alignment .
2017-06-30 15:43:03 -04:00
*/
2017-05-19 16:17:45 -04:00
struct visor_vbus_headerinfo {
2017-06-30 15:43:03 -04:00
u32 struct_bytes ;
u32 device_info_struct_bytes ;
u32 dev_info_count ;
u32 chp_info_offset ;
u32 bus_info_offset ;
u32 dev_info_offset ;
2014-07-29 15:09:40 -04:00
u8 reserved [ 104 ] ;
2017-03-17 11:27:16 -04:00
} __packed ;
2014-03-04 07:58:07 -06:00
2017-06-30 15:43:03 -04:00
/*
* struct visor_vbus_channel
* @ channel_header : Initialized by server .
* @ hdr_info : Initialized by server .
* @ chp_info : Describes client chipset device and driver .
* @ bus_info : Describes client bus device and driver .
* @ dev_info : Describes client device and driver for each device on the
* bus .
*/
2017-05-19 16:17:45 -04:00
struct visor_vbus_channel {
2017-06-30 15:43:03 -04:00
struct channel_header channel_header ;
struct visor_vbus_headerinfo hdr_info ;
2017-05-19 16:17:45 -04:00
struct visor_vbus_deviceinfo chp_info ;
struct visor_vbus_deviceinfo bus_info ;
struct visor_vbus_deviceinfo dev_info [ 0 ] ;
2017-03-17 11:27:16 -04:00
} __packed ;
2014-03-04 07:58:07 -06:00
# endif