Staging: hv: typdef fixes for HvSynicApi.h
authorGreg Kroah-Hartman <gregkh@suse.de>
Thu, 20 Aug 2009 19:11:26 +0000 (12:11 -0700)
committerGreg Kroah-Hartman <gregkh@suse.de>
Tue, 15 Sep 2009 19:01:57 +0000 (12:01 -0700)
Still some volatile mis-usages left to fix.

Cc: Hank Janssen <hjanssen@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/staging/hv/Channel.c
drivers/staging/hv/ChannelMgmt.c
drivers/staging/hv/Connection.c
drivers/staging/hv/Hv.c
drivers/staging/hv/Hv.h
drivers/staging/hv/Vmbus.c
drivers/staging/hv/include/HvHcApi.h
drivers/staging/hv/include/HvSynicApi.h

index a200128d0c1ff6cf55ae54b4ee9713f6b3e13ad5..f8607320de486e2756b63841a36a2e480da0990b 100644 (file)
@@ -42,7 +42,7 @@ static void VmbusChannelSetEvent(struct vmbus_channel *channel);
 #if 0
 static void
 DumpMonitorPage(
-       HV_MONITOR_PAGE *MonitorPage
+       struct hv_monitor_page *MonitorPage
        )
 {
        int i=0;
@@ -85,7 +85,7 @@ Description:
 --*/
 static void VmbusChannelSetEvent(struct vmbus_channel *Channel)
 {
-       HV_MONITOR_PAGE *monitorPage;
+       struct hv_monitor_page *monitorPage;
 
        DPRINT_ENTER(VMBUS);
 
@@ -96,7 +96,7 @@ static void VmbusChannelSetEvent(struct vmbus_channel *Channel)
                        (unsigned long *) gVmbusConnection.SendInterruptPage +
                        (Channel->OfferMsg.ChildRelId >> 5) );
 
-               monitorPage = (HV_MONITOR_PAGE*)gVmbusConnection.MonitorPages;
+               monitorPage = (struct hv_monitor_page *)gVmbusConnection.MonitorPages;
                monitorPage++; /* Get the child to parent monitor page */
 
                set_bit(Channel->MonitorBit,
@@ -114,7 +114,7 @@ static void VmbusChannelSetEvent(struct vmbus_channel *Channel)
 #if 0
 static void VmbusChannelClearEvent(struct vmbus_channel *channel)
 {
-       HV_MONITOR_PAGE *monitorPage;
+       struct hv_monitor_page *monitorPage;
 
        DPRINT_ENTER(VMBUS);
 
@@ -124,7 +124,7 @@ static void VmbusChannelClearEvent(struct vmbus_channel *channel)
                clear_bit(Channel->OfferMsg.ChildRelId & 31,
                          (unsigned long *) gVmbusConnection.SendInterruptPage + (Channel->OfferMsg.ChildRelId >> 5));
 
-               monitorPage = (HV_MONITOR_PAGE*)gVmbusConnection.MonitorPages;
+               monitorPage = (struct hv_monitor_page *)gVmbusConnection.MonitorPages;
                monitorPage++; /* Get the child to parent monitor page */
 
                clear_bit(Channel->MonitorBit,
@@ -147,7 +147,7 @@ Description:
 void VmbusChannelGetDebugInfo(struct vmbus_channel *Channel,
                              struct vmbus_channel_debug_info *DebugInfo)
 {
-       HV_MONITOR_PAGE *monitorPage;
+       struct hv_monitor_page *monitorPage;
     u8 monitorGroup    = (u8)Channel->OfferMsg.MonitorId / 32;
     u8 monitorOffset   = (u8)Channel->OfferMsg.MonitorId % 32;
        /* u32 monitorBit       = 1 << monitorOffset; */
@@ -157,7 +157,7 @@ void VmbusChannelGetDebugInfo(struct vmbus_channel *Channel,
        memcpy(&DebugInfo->InterfaceType, &Channel->OfferMsg.Offer.InterfaceType, sizeof(struct hv_guid));
        memcpy(&DebugInfo->InterfaceInstance, &Channel->OfferMsg.Offer.InterfaceInstance, sizeof(struct hv_guid));
 
-       monitorPage = (HV_MONITOR_PAGE*)gVmbusConnection.MonitorPages;
+       monitorPage = (struct hv_monitor_page *)gVmbusConnection.MonitorPages;
 
        DebugInfo->MonitorId = Channel->OfferMsg.MonitorId;
 
index ec078bdfd40c4c98b639e511b1056ff7234b86d8..3172759edaf09f5cfc8c1f7eac117cea53b6bf16 100644 (file)
@@ -701,7 +701,7 @@ Description:
 --*/
 void VmbusOnChannelMessage(void *Context)
 {
-       HV_MESSAGE *msg=(HV_MESSAGE*)Context;
+       struct hv_message *msg = Context;
        VMBUS_CHANNEL_MESSAGE_HEADER* hdr;
        int size;
 
index 9083f33a4b3dd62c339769916ad697839a1a21d0..5cdfbc993174c190b100df5a6dc7e257705b607a 100644 (file)
@@ -390,7 +390,7 @@ Description:
 int VmbusPostMessage(void *buffer, size_t bufferLen)
 {
        int ret=0;
-       HV_CONNECTION_ID connId;
+       union hv_connection_id connId;
 
 
        connId.Asu32 =0;
index 83d0cae33cf738365f97b4d96f40e4cb836c783a..468401b48e42eb2ee84cb5dbd099155bdbd68926 100644 (file)
@@ -385,8 +385,8 @@ Description:
 
 --*/
 HV_STATUS HvPostMessage(
-       HV_CONNECTION_ID connectionId,
-       HV_MESSAGE_TYPE  messageType,
+       union hv_connection_id connectionId,
+       enum hv_message_type messageType,
        void *            payload,
        size_t           payloadSize
        )
@@ -461,10 +461,10 @@ Description:
 int HvSynicInit (u32 irqVector)
 {
        u64                     version;
-       HV_SYNIC_SIMP   simp;
-       HV_SYNIC_SIEFP  siefp;
-    HV_SYNIC_SINT      sharedSint;
-       HV_SYNIC_SCONTROL sctrl;
+       union hv_synic_simp simp;
+       union hv_synic_siefp siefp;
+       union hv_synic_sint sharedSint;
+       union hv_synic_scontrol sctrl;
        u64                     guestID;
        int ret=0;
 
@@ -600,9 +600,9 @@ Description:
 --*/
 void HvSynicCleanup(void)
 {
-    HV_SYNIC_SINT      sharedSint;
-       HV_SYNIC_SIMP   simp;
-       HV_SYNIC_SIEFP  siefp;
+       union hv_synic_sint sharedSint;
+       union hv_synic_simp simp;
+       union hv_synic_siefp siefp;
 
        DPRINT_ENTER(VMBUS);
 
index d8a4fe5e7ed186251339598e0fcfdc2a352d9a2d..3f205c696b66d494bb47e8d5024bfa9ac1000cc2 100644 (file)
@@ -135,8 +135,8 @@ extern int HvInit(void);
 
 extern void HvCleanup(void);
 
-extern HV_STATUS HvPostMessage(HV_CONNECTION_ID connectionId,
-                              HV_MESSAGE_TYPE messageType,
+extern HV_STATUS HvPostMessage(union hv_connection_id connectionId,
+                              enum hv_message_type messageType,
                               void *payload,
                               size_t payloadSize);
 
index 58ed469c18c711f301a9f5b1436f17cd60deab51..e39cea1434a6edf91eb1b047d34b01bbacba6f7b 100644 (file)
@@ -407,8 +407,8 @@ VmbusOnMsgDPC(
 {
        void *page_addr = gHvContext.synICMessagePage[0];
 
-       HV_MESSAGE* msg = (HV_MESSAGE*)page_addr + VMBUS_MESSAGE_SINT;
-       HV_MESSAGE *copied;
+       struct hv_message *msg = (struct hv_message *)page_addr + VMBUS_MESSAGE_SINT;
+       struct hv_message *copied;
        while (1)
        {
                if (msg->Header.MessageType == HvMessageTypeNone) /* no msg */
@@ -417,13 +417,13 @@ VmbusOnMsgDPC(
                }
                else
                {
-                       copied = kmalloc(sizeof(HV_MESSAGE), GFP_ATOMIC);
+                       copied = kmalloc(sizeof(*copied), GFP_ATOMIC);
                        if (copied == NULL)
                        {
                                continue;
                        }
 
-                       memcpy(copied, msg, sizeof(HV_MESSAGE));
+                       memcpy(copied, msg, sizeof(*copied));
                        osd_schedule_callback(gVmbusConnection.WorkQueue,
                                              VmbusOnChannelMessage,
                                              (void *)copied);
@@ -490,13 +490,13 @@ VmbusOnISR(
        int ret=0;
        /* struct page* page; */
        void *page_addr;
-       HV_MESSAGE* msg;
-       HV_SYNIC_EVENT_FLAGS* event;
+       struct hv_message *msg;
+       union hv_synic_event_flags *event;
 
        /* page = SynICMessagePage[0]; */
        /* page_addr = page_address(page); */
        page_addr = gHvContext.synICMessagePage[0];
-       msg = (HV_MESSAGE*)page_addr + VMBUS_MESSAGE_SINT;
+       msg = (struct hv_message *)page_addr + VMBUS_MESSAGE_SINT;
 
        DPRINT_ENTER(VMBUS);
 
@@ -509,7 +509,7 @@ VmbusOnISR(
 
        /* TODO: Check if there are events to be process */
        page_addr = gHvContext.synICEventPage[0];
-       event = (HV_SYNIC_EVENT_FLAGS*)page_addr + VMBUS_MESSAGE_SINT;
+       event = (union hv_synic_event_flags *)page_addr + VMBUS_MESSAGE_SINT;
 
        /* Since we are a child, we only need to check bit 0 */
        if (test_and_clear_bit(0, (unsigned long *) &event->Flags32[0]))
index d4be571e220cfd281fda56f42f28674b64f86d57..c03926a2f0b726dc347083c0b9e278e162a6b387 100644 (file)
@@ -32,16 +32,16 @@ enum hv_call_code {
 
 /* Definition of the HvPostMessage hypercall input structure. */
 struct hv_input_post_message {
-       HV_CONNECTION_ID ConnectionId;
+       union hv_connection_id ConnectionId;
        u32 Reserved;
-       HV_MESSAGE_TYPE MessageType;
+       enum hv_message_type MessageType;
        u32 PayloadSize;
        u64 Payload[HV_MESSAGE_PAYLOAD_QWORD_COUNT];
 };
 
 /* Definition of the HvSignalEvent hypercall input structure. */
 struct hv_input_signal_event {
-       HV_CONNECTION_ID ConnectionId;
+       union hv_connection_id ConnectionId;
        u16 FlagNumber;
        u16 RsvdZ;
 };
index 4215d9919cc4d5a99289295f2e381f0a876cb633..7e3db63d2e1de1be6078934a7b0b1f8dd238c151 100644 (file)
@@ -71,7 +71,7 @@
 #define HV_EVENT_FLAGS_DWORD_COUNT     (256 / sizeof(u32))
 
 /* Define hypervisor message types. */
-typedef enum _HV_MESSAGE_TYPE {
+enum hv_message_type {
        HvMessageTypeNone                       = 0x00000000,
 
        /* Memory access messages. */
@@ -96,58 +96,52 @@ typedef enum _HV_MESSAGE_TYPE {
        HvMessageTypeX64ExceptionIntercept      = 0x80010003,
        HvMessageTypeX64ApicEoi                 = 0x80010004,
        HvMessageTypeX64LegacyFpError           = 0x80010005
-} HV_MESSAGE_TYPE, *PHV_MESSAGE_TYPE;
+};
 
 /* Define the number of synthetic interrupt sources. */
 #define HV_SYNIC_SINT_COUNT            (16)
 #define HV_SYNIC_STIMER_COUNT          (4)
 
-/* Define the synthetic interrupt source index type. */
-typedef u32 HV_SYNIC_SINT_INDEX, *PHV_SYNIC_SINT_INDEX;
-
-/* Define partition identifier type. */
-typedef u64 HV_PARTITION_ID, *PHV_PARTITION_ID;
-
 /* Define invalid partition identifier. */
-#define HV_PARTITION_ID_INVALID                ((HV_PARTITION_ID) 0x0)
+#define HV_PARTITION_ID_INVALID                ((u64)0x0)
 
 /* Define connection identifier type. */
-typedef union _HV_CONNECTION_ID {
+union hv_connection_id {
        u32 Asu32;
        struct {
                u32 Id:24;
                u32 Reserved:8;
        } u;
-} HV_CONNECTION_ID, *PHV_CONNECTION_ID;
+};
 
 /* Define port identifier type. */
-typedef union _HV_PORT_ID {
+union hv_port_id {
        u32 Asu32;
        struct {
                u32 Id:24;
                u32 Reserved:8;
        } u ;
-} HV_PORT_ID, *PHV_PORT_ID;
+};
 
 /* Define port type. */
-typedef enum _HV_PORT_TYPE {
+enum hv_port_type {
        HvPortTypeMessage       = 1,
        HvPortTypeEvent         = 2,
        HvPortTypeMonitor       = 3
-} HV_PORT_TYPE, *PHV_PORT_TYPE;
+};
 
 /* Define port information structure. */
-typedef struct _HV_PORT_INFO {
-       HV_PORT_TYPE PortType;
+struct hv_port_info {
+       enum hv_port_type PortType;
        u32 Padding;
        union {
                struct {
-                       HV_SYNIC_SINT_INDEX TargetSint;
+                       u32 TargetSint;
                        u32 TargetVp;
                        u64 RsvdZ;
                } MessagePortInfo;
                struct {
-                       HV_SYNIC_SINT_INDEX TargetSint;
+                       u32 TargetSint;
                        u32 TargetVp;
                        u16 BaseFlagNumber;
                        u16 FlagCount;
@@ -158,11 +152,10 @@ typedef struct _HV_PORT_INFO {
                        u64 RsvdZ;
                } MonitorPortInfo;
        };
-} HV_PORT_INFO, *PHV_PORT_INFO;
-typedef const HV_PORT_INFO *PCHV_PORT_INFO;
+};
 
-typedef struct _HV_CONNECTION_INFO {
-       HV_PORT_TYPE PortType;
+struct hv_connection_info {
+       enum hv_port_type PortType;
        u32 Padding;
        union {
                struct {
@@ -175,76 +168,75 @@ typedef struct _HV_CONNECTION_INFO {
                        u64 MonitorAddress;
                } MonitorConnectionInfo;
        };
-} HV_CONNECTION_INFO, *PHV_CONNECTION_INFO;
-typedef const HV_CONNECTION_INFO *PCHV_CONNECTION_INFO;
+};
 
 /* Define synthetic interrupt controller message flags. */
-typedef union _HV_MESSAGE_FLAGS {
+union hv_message_flags {
        u8 Asu8;
        struct {
                u8 MessagePending:1;
                u8 Reserved:7;
        };
-} HV_MESSAGE_FLAGS, *PHV_MESSAGE_FLAGS;
+};
 
 /* Define synthetic interrupt controller message header. */
-typedef struct _HV_MESSAGE_HEADER {
-       HV_MESSAGE_TYPE MessageType;
+struct hv_message_header {
+       enum hv_message_type MessageType;
        u8 PayloadSize;
-       HV_MESSAGE_FLAGS MessageFlags;
+       union hv_message_flags MessageFlags;
        u8 Reserved[2];
        union {
-               HV_PARTITION_ID Sender;
-               HV_PORT_ID Port;
+               u64 Sender;
+               union hv_port_id Port;
        };
-} HV_MESSAGE_HEADER, *PHV_MESSAGE_HEADER;
+};
 
 /* Define timer message payload structure. */
-typedef struct _HV_TIMER_MESSAGE_PAYLOAD {
+struct hv_timer_message_payload {
        u32 TimerIndex;
        u32 Reserved;
        u64 ExpirationTime;     /* When the timer expired */
        u64 DeliveryTime;       /* When the message was delivered */
-} HV_TIMER_MESSAGE_PAYLOAD, *PHV_TIMER_MESSAGE_PAYLOAD;
+};
 
 /* Define synthetic interrupt controller message format. */
-typedef struct _HV_MESSAGE {
-       HV_MESSAGE_HEADER Header;
+struct hv_message {
+       struct hv_message_header Header;
        union {
                u64 Payload[HV_MESSAGE_PAYLOAD_QWORD_COUNT];
        } u ;
-} HV_MESSAGE, *PHV_MESSAGE;
+};
 
 /* Define the number of message buffers associated with each port. */
 #define HV_PORT_MESSAGE_BUFFER_COUNT   (16)
 
 /* Define the synthetic interrupt message page layout. */
-typedef struct _HV_MESSAGE_PAGE {
-       volatile HV_MESSAGE SintMessage[HV_SYNIC_SINT_COUNT];
-} HV_MESSAGE_PAGE, *PHV_MESSAGE_PAGE;
+struct hv_message_page {
+       volatile struct hv_message SintMessage[HV_SYNIC_SINT_COUNT];
+};
 
 /* Define the synthetic interrupt controller event flags format. */
-typedef union _HV_SYNIC_EVENT_FLAGS {
+union hv_synic_event_flags {
        u8 Flags8[HV_EVENT_FLAGS_BYTE_COUNT];
        u32 Flags32[HV_EVENT_FLAGS_DWORD_COUNT];
-} HV_SYNIC_EVENT_FLAGS, *PHV_SYNIC_EVENT_FLAGS;
+};
 
 /* Define the synthetic interrupt flags page layout. */
-typedef struct _HV_SYNIC_EVENT_FLAGS_PAGE {
-       volatile HV_SYNIC_EVENT_FLAGS SintEventFlags[HV_SYNIC_SINT_COUNT];
-} HV_SYNIC_EVENT_FLAGS_PAGE, *PHV_SYNIC_EVENT_FLAGS_PAGE;
+struct hv_synic_event_flags_page {
+       volatile union hv_synic_event_flags SintEventFlags[HV_SYNIC_SINT_COUNT];
+};
 
 /* Define SynIC control register. */
-typedef union _HV_SYNIC_SCONTROL {
+union hv_synic_scontrol {
        u64 AsUINT64;
        struct {
                u64 Enable:1;
                u64 Reserved:63;
        };
-} HV_SYNIC_SCONTROL, *PHV_SYNIC_SCONTROL;
+};
 
 /* Define synthetic interrupt source. */
-typedef union _HV_SYNIC_SINT {
+union hv_synic_sint {
        u64 AsUINT64;
        struct {
                u64 Vector:8;
@@ -253,54 +245,53 @@ typedef union _HV_SYNIC_SINT {
                u64 AutoEoi:1;
                u64 Reserved2:46;
        };
-} HV_SYNIC_SINT, *PHV_SYNIC_SINT;
+};
 
 /* Define the format of the SIMP register */
-typedef union _HV_SYNIC_SIMP {
+union hv_synic_simp {
        u64 AsUINT64;
        struct {
                u64 SimpEnabled:1;
                u64 Preserved:11;
                u64 BaseSimpGpa:52;
        };
-} HV_SYNIC_SIMP, *PHV_SYNIC_SIMP;
-
+};
 
 /* Define the format of the SIEFP register */
-typedef union _HV_SYNIC_SIEFP {
+union hv_synic_siefp {
        u64 AsUINT64;
        struct {
                u64 SiefpEnabled:1;
                u64 Preserved:11;
                u64 BaseSiefpGpa:52;
        };
-} HV_SYNIC_SIEFP, *PHV_SYNIC_SIEFP;
+};
 
 /* Definitions for the monitored notification facility */
-typedef union _HV_MONITOR_TRIGGER_GROUP {
+union hv_monitor_trigger_group {
        u64 AsUINT64;
        struct {
                u32 Pending;
                u32 Armed;
        };
-} HV_MONITOR_TRIGGER_GROUP, *PHV_MONITOR_TRIGGER_GROUP;
+};
 
-typedef struct _HV_MONITOR_PARAMETER {
-       HV_CONNECTION_ID ConnectionId;
+struct hv_monitor_parameter {
+       union hv_connection_id ConnectionId;
        u16 FlagNumber;
        u16 RsvdZ;
-} HV_MONITOR_PARAMETER, *PHV_MONITOR_PARAMETER;
+};
 
-typedef union _HV_MONITOR_TRIGGER_STATE {
+union hv_monitor_trigger_state {
        u32 Asu32;
 
        struct {
                u32 GroupEnable:4;
                u32 RsvdZ:28;
        };
-} HV_MONITOR_TRIGGER_STATE, *PHV_MONITOR_TRIGGER_STATE;
+};
 
-/* HV_MONITOR_PAGE Layout */
+/* struct hv_monitor_page Layout */
 /* ------------------------------------------------------ */
 /* | 0   | TriggerState (4 bytes) | Rsvd1 (4 bytes)     | */
 /* | 8   | TriggerGroup[0]                              | */
@@ -319,11 +310,11 @@ typedef union _HV_MONITOR_TRIGGER_STATE {
 /* | ...                                                | */
 /* | 840 | Rsvd4[0]                                     | */
 /* ------------------------------------------------------ */
-typedef struct _HV_MONITOR_PAGE {
-       HV_MONITOR_TRIGGER_STATE TriggerState;
+struct hv_monitor_page {
+       union hv_monitor_trigger_state TriggerState;
        u32 RsvdZ1;
 
-       HV_MONITOR_TRIGGER_GROUP TriggerGroup[4];
+       union hv_monitor_trigger_group TriggerGroup[4];
        u64 RsvdZ2[3];
 
        s32 NextCheckTime[4][32];
@@ -331,10 +322,9 @@ typedef struct _HV_MONITOR_PAGE {
        u16 Latency[4][32];
        u64 RsvdZ3[32];
 
-       HV_MONITOR_PARAMETER Parameter[4][32];
+       struct hv_monitor_parameter Parameter[4][32];
 
        u8 RsvdZ4[1984];
-} HV_MONITOR_PAGE, *PHV_MONITOR_PAGE;
-typedef volatile HV_MONITOR_PAGE* PVHV_MONITOR_PAGE;
+};
 
 #endif