kvm-guest-drivers-windows
82 строки · 3.2 Кб
1/*
2* Implementation of memory & port access routines required by VirtioLib
3*
4* Copyright (c) 2016-2017 Red Hat, Inc.
5*
6* Author(s):
7* Ladi Prosek <lprosek@redhat.com>
8*
9* Redistribution and use in source and binary forms, with or without
10* modification, are permitted provided that the following conditions
11* are met :
12* 1. Redistributions of source code must retain the above copyright
13* notice, this list of conditions and the following disclaimer.
14* 2. Redistributions in binary form must reproduce the above copyright
15* notice, this list of conditions and the following disclaimer in the
16* documentation and / or other materials provided with the distribution.
17* 3. Neither the names of the copyright holders nor the names of their contributors
18* may be used to endorse or promote products derived from this software
19* without specific prior written permission.
20* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' AND
21* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23* ARE DISCLAIMED.IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE
24* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30* SUCH DAMAGE.
31*/
32#include "osdep.h"
33#include "virtio_pci.h"
34
35/* The lower 64k of memory is never mapped so we can use the same routines
36* for both port I/O and memory access and use the address alone to decide
37* which space to use.
38*/
39#define PORT_MASK 0xFFFF
40
41/* READ_REGISTER_* and WRITE_REGISTER_* take volatile ptr in newer DDKs */
42#define _VOLATILE volatile
43
44#define READ_PORT_OR_REGISTER(address, width) \
45(address & ~PORT_MASK) ? \
46READ_REGISTER_##width((_VOLATILE width *)address) : \
47READ_PORT_##width((width *)address)
48
49#define WRITE_PORT_OR_REGISTER(address, width, value) \
50(address & ~PORT_MASK) ? \
51WRITE_REGISTER_##width((_VOLATILE width *)address, value) : \
52WRITE_PORT_##width((width *)address, value)
53
54u8 ReadVirtIODeviceByte(ULONG_PTR ulRegister)
55{
56return READ_PORT_OR_REGISTER(ulRegister, UCHAR);
57}
58
59void WriteVirtIODeviceByte(ULONG_PTR ulRegister, u8 bValue)
60{
61WRITE_PORT_OR_REGISTER(ulRegister, UCHAR, bValue);
62}
63
64u16 ReadVirtIODeviceWord(ULONG_PTR ulRegister)
65{
66return READ_PORT_OR_REGISTER(ulRegister, USHORT);
67}
68
69void WriteVirtIODeviceWord(ULONG_PTR ulRegister, u16 wValue)
70{
71WRITE_PORT_OR_REGISTER(ulRegister, USHORT, wValue);
72}
73
74u32 ReadVirtIODeviceRegister(ULONG_PTR ulRegister)
75{
76return READ_PORT_OR_REGISTER(ulRegister, ULONG);
77}
78
79void WriteVirtIODeviceRegister(ULONG_PTR ulRegister, u32 ulValue)
80{
81WRITE_PORT_OR_REGISTER(ulRegister, ULONG, ulValue);
82}
83