Coverage Report

Created: 2026-03-21 06:29

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/hbfa-fl/HBFA/UefiHostFuzzTestCasePkg/TestCase/OvmfPkg/VirtioPciDeviceDxe/TestVirtioPciDevice.c
Line
Count
Source
1
/** @file
2
3
Copyright (c) 2018, Intel Corporation. All rights reserved.<BR>
4
SPDX-License-Identifier: BSD-2-Clause-Patent
5
6
**/
7
8
#include <stdio.h>
9
#include <stdlib.h>
10
#include <string.h>
11
#include <assert.h>
12
13
#include <Uefi.h>
14
15
#include <Library/BaseLib.h>
16
#include <Library/DebugLib.h>
17
#include <Library/BaseMemoryLib.h>
18
#include <Library/MemoryAllocationLib.h>
19
#include <Library/VirtioPciDeviceStubLib.h>
20
#include <Library/PciCapPciIoLib.h>
21
#include <Library/PciCapLib.h>
22
23
3.29k
#define TOTAL_SIZE   (512 * 1024)
24
#define BLOCK_SIZE   (512)
25
#define IO_ALIGN     (1)
26
27
UINTN
28
EFIAPI
29
GetMaxBufferSize (
30
  VOID
31
  )
32
3.29k
{
33
3.29k
  return TOTAL_SIZE;
34
3.29k
}
35
36
EFI_STATUS
37
EFIAPI
38
ParseCapabilities (
39
  IN OUT VIRTIO_1_0_DEV *Device
40
  )
41
387
{
42
387
  EFI_STATUS   Status;
43
387
  PCI_CAP_DEV  *PciDevice;
44
387
  PCI_CAP_LIST *CapList;
45
387
  UINT16       VendorInstance;
46
387
  PCI_CAP      *VendorCap;
47
48
387
  Status = PciCapPciIoDeviceInit (Device->PciIo, &PciDevice);
49
387
  if (EFI_ERROR (Status)) {
50
0
    return Status;
51
0
  }
52
53
387
  Status = PciCapListInit (PciDevice, &CapList);
54
387
  if (EFI_ERROR (Status)) {
55
109
    goto UninitPciDevice;
56
109
  }
57
58
278
  for (VendorInstance = 0;
59
654
       !EFI_ERROR (PciCapListFindCap (CapList, PciCapNormal,
60
278
                     EFI_PCI_CAPABILITY_ID_VENDOR, VendorInstance,
61
278
                     &VendorCap));
62
417
       VendorInstance++) {
63
417
    UINT8             CapLen;
64
417
    VIRTIO_PCI_CAP    VirtIoCap;
65
417
    VIRTIO_1_0_CONFIG *ParsedConfig;
66
67
    //
68
    // Big enough to accommodate a VIRTIO_PCI_CAP structure?
69
    //
70
417
    Status = PciCapRead (PciDevice, VendorCap,
71
417
               OFFSET_OF (EFI_PCI_CAPABILITY_VENDOR_HDR, Length), &CapLen,
72
417
               sizeof CapLen);
73
417
    if (EFI_ERROR (Status)) {
74
0
      goto UninitCapList;
75
0
    }
76
417
    if (CapLen < sizeof VirtIoCap) {
77
      //
78
      // Too small, move to next.
79
      //
80
232
      continue;
81
232
    }
82
83
    //
84
    // Read interesting part of capability.
85
    //
86
185
    Status = PciCapRead (PciDevice, VendorCap, 0, &VirtIoCap, sizeof VirtIoCap);
87
185
    if (EFI_ERROR (Status)) {
88
28
      goto UninitCapList;
89
28
    }
90
91
157
    switch (VirtIoCap.ConfigType) {
92
38
    case VIRTIO_PCI_CAP_COMMON_CFG:
93
38
      ParsedConfig = &Device->CommonConfig;
94
38
      break;
95
52
    case VIRTIO_PCI_CAP_NOTIFY_CFG:
96
52
      ParsedConfig = &Device->NotifyConfig;
97
52
      break;
98
27
    case VIRTIO_PCI_CAP_DEVICE_CFG:
99
27
      ParsedConfig = &Device->SpecificConfig;
100
27
      break;
101
40
    default:
102
      //
103
      // Capability is not interesting.
104
      //
105
40
      continue;
106
157
    }
107
108
    //
109
    // Save the location of the register block into ParsedConfig.
110
    //
111
117
    Status = GetBarType (Device->PciIo, VirtIoCap.Bar, &ParsedConfig->BarType);
112
117
    if (EFI_ERROR (Status)) {
113
10
      goto UninitCapList;
114
10
    }
115
107
    ParsedConfig->Bar    = VirtIoCap.Bar;
116
107
    ParsedConfig->Offset = VirtIoCap.Offset;
117
107
    ParsedConfig->Length = VirtIoCap.Length;
118
119
107
    if (VirtIoCap.ConfigType == VIRTIO_PCI_CAP_NOTIFY_CFG) {
120
      //
121
      // This capability has an additional field called NotifyOffsetMultiplier;
122
      // parse it too.
123
      //
124
48
      if (CapLen < sizeof VirtIoCap + sizeof Device->NotifyOffsetMultiplier) {
125
        //
126
        // Too small, move to next.
127
        //
128
22
        continue;
129
22
      }
130
131
26
      Status = PciCapRead (PciDevice, VendorCap, sizeof VirtIoCap,
132
26
                 &Device->NotifyOffsetMultiplier,
133
26
                 sizeof Device->NotifyOffsetMultiplier);
134
26
      if (EFI_ERROR (Status)) {
135
3
        goto UninitCapList;
136
3
      }
137
26
    }
138
139
    //
140
    // Capability parsed successfully.
141
    //
142
82
    ParsedConfig->Exists = TRUE;
143
82
  }
144
145
237
  ASSERT_EFI_ERROR (Status);
146
147
278
UninitCapList:
148
278
  PciCapListUninit (CapList);
149
150
387
UninitPciDevice:
151
387
  PciCapPciIoDeviceUninit (PciDevice);
152
153
387
  return Status;
154
278
}
155
156
VOID
157
EFIAPI
158
RunTestHarness(
159
  IN VOID  *TestBuffer,
160
  IN UINTN TestBufferSize
161
  )
162
497
{
163
497
  VIRTIO_1_0_DEV         *VirtioPciDevice;
164
497
  EFI_STATUS             Status;
165
497
  EFI_PCI_IO_PROTOCOL    *PciIo;
166
167
497
  VirtioPciDevice = (VIRTIO_1_0_DEV *) AllocateZeroPool(sizeof (*VirtioPciDevice));
168
  
169
497
  PciIo = (EFI_PCI_IO_PROTOCOL *)AllocateZeroPool(sizeof (*PciIo));
170
171
497
  VirtioPciDevice->PciIo = PciIo; 
172
  
173
497
  Status = InitVirtioPciDevice (VirtioPciDevice, TestBuffer, TestBufferSize, PciIo);
174
  
175
497
  if (!EFI_ERROR(Status)) {
176
387
    ParseCapabilities (VirtioPciDevice);
177
387
  }
178
  
179
497
  FreePool (PciIo);
180
497
  FreePool (VirtioPciDevice);
181
497
}