Staging: hv: hv_mouse: reorder functions to remove forward declarations

This removes almost all forward declarations and makes all functions
static, as there should not be any global functions in this module at
all.

Cc: Hank Janssen <hjanssen@microsoft.com>
Cc: K. Y. Srinivasan <kys@microsoft.com>
Cc: Haiyang Zhang <haiyangz@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
Greg Kroah-Hartman 2011-03-02 18:50:15 -08:00
parent 037b653aae
commit ac2c9033d6

View File

@ -202,19 +202,6 @@ static const struct hv_guid gMousevscDeviceType = {
0xB9, 0x8B, 0x8B, 0xA1, 0xA1, 0xF3, 0xF9, 0x5A}
};
/*
* Internal routines
*/
static int MousevscOnDeviceAdd(struct hv_device *Device, void *AdditionalInfo);
static int MousevscOnDeviceRemove(struct hv_device *Device);
static void MousevscOnCleanup(struct hv_driver *Device);
static void MousevscOnChannelCallback(void *Context);
static int MousevscConnectToVsp(struct hv_device *Device);
static void MousevscOnReceive(struct hv_device *Device,
struct vmpacket_descriptor *Packet);
@ -334,250 +321,7 @@ static struct mousevsc_dev *FinalReleaseInputDevice(struct hv_device *Device)
return inputDevice;
}
static int mouse_vsc_initialize(struct hv_driver *Driver)
{
struct mousevsc_drv_obj *inputDriver =
(struct mousevsc_drv_obj *)Driver;
int ret = 0;
Driver->name = gDriverName;
memcpy(&Driver->dev_type, &gMousevscDeviceType,
sizeof(struct hv_guid));
/* Setup the dispatch table */
inputDriver->Base.dev_add = MousevscOnDeviceAdd;
inputDriver->Base.dev_rm = MousevscOnDeviceRemove;
inputDriver->Base.cleanup = MousevscOnCleanup;
return ret;
}
/*
*
* Name:
* MousevscOnDeviceAdd()
*
* Description:
* Callback when the device belonging to this driver is added
*
*/
int
MousevscOnDeviceAdd(struct hv_device *Device, void *AdditionalInfo)
{
int ret = 0;
struct mousevsc_dev *inputDevice;
struct mousevsc_drv_obj *inputDriver;
struct input_dev_info deviceInfo;
inputDevice = AllocInputDevice(Device);
if (!inputDevice) {
ret = -1;
goto Cleanup;
}
inputDevice->bInitializeComplete = false;
/* Open the channel */
ret = vmbus_open(Device->channel,
INPUTVSC_SEND_RING_BUFFER_SIZE,
INPUTVSC_RECV_RING_BUFFER_SIZE,
NULL,
0,
MousevscOnChannelCallback,
Device
);
if (ret != 0) {
pr_err("unable to open channel: %d", ret);
return -1;
}
pr_info("InputVsc channel open: %d", ret);
ret = MousevscConnectToVsp(Device);
if (ret != 0) {
pr_err("unable to connect channel: %d", ret);
vmbus_close(Device->channel);
return ret;
}
inputDriver = (struct mousevsc_drv_obj *)inputDevice->Device->drv;
deviceInfo.VendorID = inputDevice->DeviceAttr.VendorID;
deviceInfo.ProductID = inputDevice->DeviceAttr.ProductID;
deviceInfo.VersionNumber = inputDevice->DeviceAttr.VersionNumber;
strcpy(deviceInfo.Name, "Microsoft Vmbus HID-compliant Mouse");
/* Send the device info back up */
deviceinfo_callback(Device, &deviceInfo);
/* Send the report desc back up */
/* workaround SA-167 */
if (inputDevice->ReportDesc[14] == 0x25)
inputDevice->ReportDesc[14] = 0x29;
reportdesc_callback(Device, inputDevice->ReportDesc,
inputDevice->ReportDescSize);
inputDevice->bInitializeComplete = true;
Cleanup:
return ret;
}
int
MousevscConnectToVsp(struct hv_device *Device)
{
int ret = 0;
struct mousevsc_dev *inputDevice;
struct mousevsc_prt_msg *request;
struct mousevsc_prt_msg *response;
inputDevice = GetInputDevice(Device);
if (!inputDevice) {
pr_err("unable to get input device...device being destroyed?");
return -1;
}
init_waitqueue_head(&inputDevice->ProtocolWaitEvent);
init_waitqueue_head(&inputDevice->DeviceInfoWaitEvent);
request = &inputDevice->ProtocolReq;
/*
* Now, initiate the vsc/vsp initialization protocol on the open channel
*/
memset(request, sizeof(struct mousevsc_prt_msg), 0);
request->PacketType = PipeMessageData;
request->DataSize = sizeof(struct synthhid_protocol_request);
request->u.Request.Header.Type = SynthHidProtocolRequest;
request->u.Request.Header.Size = sizeof(unsigned long);
request->u.Request.VersionRequested.AsDWord =
SYNTHHID_INPUT_VERSION_DWORD;
pr_info("synthhid protocol request...");
ret = vmbus_sendpacket(Device->channel, request,
sizeof(struct pipe_prt_msg) -
sizeof(unsigned char) +
sizeof(struct synthhid_protocol_request),
(unsigned long)request,
VM_PKT_DATA_INBAND,
VMBUS_DATA_PACKET_FLAG_COMPLETION_REQUESTED);
if (ret != 0) {
pr_err("unable to send synthhid protocol request.");
goto Cleanup;
}
inputDevice->protocol_wait_condition = 0;
wait_event_timeout(inputDevice->ProtocolWaitEvent, inputDevice->protocol_wait_condition, msecs_to_jiffies(1000));
if (inputDevice->protocol_wait_condition == 0) {
ret = -ETIMEDOUT;
goto Cleanup;
}
response = &inputDevice->ProtocolResp;
if (!response->u.Response.Approved) {
pr_err("synthhid protocol request failed (version %d)",
SYNTHHID_INPUT_VERSION_DWORD);
ret = -1;
goto Cleanup;
}
inputDevice->device_wait_condition = 0;
wait_event_timeout(inputDevice->DeviceInfoWaitEvent, inputDevice->device_wait_condition, msecs_to_jiffies(1000));
if (inputDevice->device_wait_condition == 0) {
ret = -ETIMEDOUT;
goto Cleanup;
}
/*
* We should have gotten the device attr, hid desc and report
* desc at this point
*/
if (!inputDevice->DeviceInfoStatus)
pr_info("**** input channel up and running!! ****");
else
ret = -1;
Cleanup:
PutInputDevice(Device);
return ret;
}
/*
*
* Name:
* MousevscOnDeviceRemove()
*
* Description:
* Callback when the our device is being removed
*
*/
int
MousevscOnDeviceRemove(struct hv_device *Device)
{
struct mousevsc_dev *inputDevice;
int ret = 0;
pr_info("disabling input device (%p)...",
Device->ext);
inputDevice = ReleaseInputDevice(Device);
/*
* At this point, all outbound traffic should be disable. We only
* allow inbound traffic (responses) to proceed
*
* so that outstanding requests can be completed.
*/
while (inputDevice->NumOutstandingRequests) {
pr_info("waiting for %d requests to complete...", inputDevice->NumOutstandingRequests);
udelay(100);
}
pr_info("removing input device (%p)...", Device->ext);
inputDevice = FinalReleaseInputDevice(Device);
pr_info("input device (%p) safe to remove", inputDevice);
/* Close the channel */
vmbus_close(Device->channel);
FreeInputDevice(inputDevice);
return ret;
}
/*
*
* Name:
* MousevscOnCleanup()
*
* Description:
* Perform any cleanup when the driver is removed
*/
static void MousevscOnCleanup(struct hv_driver *drv)
{
}
static void
MousevscOnSendCompletion(struct hv_device *Device,
struct vmpacket_descriptor *Packet)
static void MousevscOnSendCompletion(struct hv_device *Device, struct vmpacket_descriptor *Packet)
{
struct mousevsc_dev *inputDevice;
void *request;
@ -598,10 +342,7 @@ MousevscOnSendCompletion(struct hv_device *Device,
PutInputDevice(Device);
}
void
MousevscOnReceiveDeviceInfo(
struct mousevsc_dev *InputDevice,
struct synthhid_device_info *DeviceInfo)
static void MousevscOnReceiveDeviceInfo(struct mousevsc_dev *InputDevice, struct synthhid_device_info *DeviceInfo)
{
int ret = 0;
struct hid_descriptor *desc;
@ -685,11 +426,7 @@ Cleanup:
wake_up(&InputDevice->DeviceInfoWaitEvent);
}
void
MousevscOnReceiveInputReport(
struct mousevsc_dev *InputDevice,
struct synthhid_input_report *InputReport)
static void MousevscOnReceiveInputReport(struct mousevsc_dev *InputDevice, struct synthhid_input_report *InputReport)
{
struct mousevsc_drv_obj *inputDriver;
@ -705,8 +442,7 @@ MousevscOnReceiveInputReport(
InputReport->Header.Size);
}
void
MousevscOnReceive(struct hv_device *Device, struct vmpacket_descriptor *Packet)
static void MousevscOnReceive(struct hv_device *Device, struct vmpacket_descriptor *Packet)
{
struct pipe_prt_msg *pipeMsg;
struct synthhid_msg *hidMsg;
@ -760,7 +496,7 @@ MousevscOnReceive(struct hv_device *Device, struct vmpacket_descriptor *Packet)
PutInputDevice(Device);
}
void MousevscOnChannelCallback(void *Context)
static void MousevscOnChannelCallback(void *Context)
{
const int packetSize = 0x100;
int ret = 0;
@ -848,6 +584,197 @@ void MousevscOnChannelCallback(void *Context)
return;
}
static int MousevscConnectToVsp(struct hv_device *Device)
{
int ret = 0;
struct mousevsc_dev *inputDevice;
struct mousevsc_prt_msg *request;
struct mousevsc_prt_msg *response;
inputDevice = GetInputDevice(Device);
if (!inputDevice) {
pr_err("unable to get input device...device being destroyed?");
return -1;
}
init_waitqueue_head(&inputDevice->ProtocolWaitEvent);
init_waitqueue_head(&inputDevice->DeviceInfoWaitEvent);
request = &inputDevice->ProtocolReq;
/*
* Now, initiate the vsc/vsp initialization protocol on the open channel
*/
memset(request, sizeof(struct mousevsc_prt_msg), 0);
request->PacketType = PipeMessageData;
request->DataSize = sizeof(struct synthhid_protocol_request);
request->u.Request.Header.Type = SynthHidProtocolRequest;
request->u.Request.Header.Size = sizeof(unsigned long);
request->u.Request.VersionRequested.AsDWord =
SYNTHHID_INPUT_VERSION_DWORD;
pr_info("synthhid protocol request...");
ret = vmbus_sendpacket(Device->channel, request,
sizeof(struct pipe_prt_msg) -
sizeof(unsigned char) +
sizeof(struct synthhid_protocol_request),
(unsigned long)request,
VM_PKT_DATA_INBAND,
VMBUS_DATA_PACKET_FLAG_COMPLETION_REQUESTED);
if (ret != 0) {
pr_err("unable to send synthhid protocol request.");
goto Cleanup;
}
inputDevice->protocol_wait_condition = 0;
wait_event_timeout(inputDevice->ProtocolWaitEvent, inputDevice->protocol_wait_condition, msecs_to_jiffies(1000));
if (inputDevice->protocol_wait_condition == 0) {
ret = -ETIMEDOUT;
goto Cleanup;
}
response = &inputDevice->ProtocolResp;
if (!response->u.Response.Approved) {
pr_err("synthhid protocol request failed (version %d)",
SYNTHHID_INPUT_VERSION_DWORD);
ret = -1;
goto Cleanup;
}
inputDevice->device_wait_condition = 0;
wait_event_timeout(inputDevice->DeviceInfoWaitEvent, inputDevice->device_wait_condition, msecs_to_jiffies(1000));
if (inputDevice->device_wait_condition == 0) {
ret = -ETIMEDOUT;
goto Cleanup;
}
/*
* We should have gotten the device attr, hid desc and report
* desc at this point
*/
if (!inputDevice->DeviceInfoStatus)
pr_info("**** input channel up and running!! ****");
else
ret = -1;
Cleanup:
PutInputDevice(Device);
return ret;
}
static int MousevscOnDeviceAdd(struct hv_device *Device, void *AdditionalInfo)
{
int ret = 0;
struct mousevsc_dev *inputDevice;
struct mousevsc_drv_obj *inputDriver;
struct input_dev_info deviceInfo;
inputDevice = AllocInputDevice(Device);
if (!inputDevice) {
ret = -1;
goto Cleanup;
}
inputDevice->bInitializeComplete = false;
/* Open the channel */
ret = vmbus_open(Device->channel,
INPUTVSC_SEND_RING_BUFFER_SIZE,
INPUTVSC_RECV_RING_BUFFER_SIZE,
NULL,
0,
MousevscOnChannelCallback,
Device
);
if (ret != 0) {
pr_err("unable to open channel: %d", ret);
return -1;
}
pr_info("InputVsc channel open: %d", ret);
ret = MousevscConnectToVsp(Device);
if (ret != 0) {
pr_err("unable to connect channel: %d", ret);
vmbus_close(Device->channel);
return ret;
}
inputDriver = (struct mousevsc_drv_obj *)inputDevice->Device->drv;
deviceInfo.VendorID = inputDevice->DeviceAttr.VendorID;
deviceInfo.ProductID = inputDevice->DeviceAttr.ProductID;
deviceInfo.VersionNumber = inputDevice->DeviceAttr.VersionNumber;
strcpy(deviceInfo.Name, "Microsoft Vmbus HID-compliant Mouse");
/* Send the device info back up */
deviceinfo_callback(Device, &deviceInfo);
/* Send the report desc back up */
/* workaround SA-167 */
if (inputDevice->ReportDesc[14] == 0x25)
inputDevice->ReportDesc[14] = 0x29;
reportdesc_callback(Device, inputDevice->ReportDesc,
inputDevice->ReportDescSize);
inputDevice->bInitializeComplete = true;
Cleanup:
return ret;
}
static int MousevscOnDeviceRemove(struct hv_device *Device)
{
struct mousevsc_dev *inputDevice;
int ret = 0;
pr_info("disabling input device (%p)...",
Device->ext);
inputDevice = ReleaseInputDevice(Device);
/*
* At this point, all outbound traffic should be disable. We only
* allow inbound traffic (responses) to proceed
*
* so that outstanding requests can be completed.
*/
while (inputDevice->NumOutstandingRequests) {
pr_info("waiting for %d requests to complete...", inputDevice->NumOutstandingRequests);
udelay(100);
}
pr_info("removing input device (%p)...", Device->ext);
inputDevice = FinalReleaseInputDevice(Device);
pr_info("input device (%p) safe to remove", inputDevice);
/* Close the channel */
vmbus_close(Device->channel);
FreeInputDevice(inputDevice);
return ret;
}
static void MousevscOnCleanup(struct hv_driver *drv)
{
}
/*
* Data types
*/
@ -892,16 +819,16 @@ static void inputreport_callback(struct hv_device *dev, void *packet, u32 len)
DPRINT_DBG(INPUTVSC_DRV, "hid_input_report (ret %d)", ret);
}
int mousevsc_hid_open(struct hid_device *hid)
static int mousevsc_hid_open(struct hid_device *hid)
{
return 0;
}
void mousevsc_hid_close(struct hid_device *hid)
static void mousevsc_hid_close(struct hid_device *hid)
{
}
int mousevsc_probe(struct device *device)
static int mousevsc_probe(struct device *device)
{
int ret = 0;
@ -932,8 +859,7 @@ int mousevsc_probe(struct device *device)
return 0;
}
int mousevsc_remove(struct device *device)
static int mousevsc_remove(struct device *device)
{
int ret = 0;
@ -1030,7 +956,7 @@ static void reportdesc_callback(struct hv_device *dev, void *packet, u32 len)
kfree(hid_dev);
}
int mousevsc_drv_exit_cb(struct device *dev, void *data)
static int mousevsc_drv_exit_cb(struct device *dev, void *data)
{
struct device **curr = (struct device **)data;
*curr = dev;
@ -1038,7 +964,7 @@ int mousevsc_drv_exit_cb(struct device *dev, void *data)
return 1;
}
void mousevsc_drv_exit(void)
static void mousevsc_drv_exit(void)
{
struct mousevsc_drv_obj *mousevsc_drv_obj = &g_mousevsc_drv.drv_obj;
struct driver_context *drv_ctx = &g_mousevsc_drv.drv_ctx;
@ -1071,6 +997,25 @@ void mousevsc_drv_exit(void)
return;
}
static int mouse_vsc_initialize(struct hv_driver *Driver)
{
struct mousevsc_drv_obj *inputDriver =
(struct mousevsc_drv_obj *)Driver;
int ret = 0;
Driver->name = gDriverName;
memcpy(&Driver->dev_type, &gMousevscDeviceType,
sizeof(struct hv_guid));
/* Setup the dispatch table */
inputDriver->Base.dev_add = MousevscOnDeviceAdd;
inputDriver->Base.dev_rm = MousevscOnDeviceRemove;
inputDriver->Base.cleanup = MousevscOnCleanup;
return ret;
}
static int __init mousevsc_init(void)
{
struct mousevsc_drv_obj *input_drv_obj = &g_mousevsc_drv.drv_obj;