summaryrefslogtreecommitdiffstats
path: root/OvmfPkg/Bhyve/Include/Library/BhyveFwCtlLib.h
blob: 13028ec4b585c49df83d00e170805d1a1ed066c8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/** @file
  bhyve firmware configuration access

  Copyright (c) 2020, Rebecca Cran <rebecca@bsdio.com>
  Copyright (c) 2015 Nahanni Systems

  SPDX-License-Identifier: BSD-2-Clause-Patent

**/

#ifndef __BHYVE_FW_CTL_LIB__
#define __BHYVE_FW_CTL_LIB__

/**
  Sysctl-like interface to read host information via a dot-separated
  ASCII OID.

  The information is copied into the buffer specified by Item. The
  size of the buffer is given by the location specified by Size
  before the call, and that location gives the amount of data copied
  after a successfull call, and after a call that returns a truncated
  value with an error return of RETURN_BUFFER_TOO_SMALL.

  The size of the available data can be determined by passing a NULL
  argument for Item. The size will be returned in the location pointed
  to by Size.

  @param[]  Name    - ASCII OID name
  @param[]  Data    - return buffer pointer
  @param[]  Size    - pointer to length

  @return    RETURN_SUCCESS          Valid data/len returned.
          RETURN_UNSUPPORTED        f/w interface not present.
          RETURN_NOT_FOUND      OID not found.
        RETURN_BUFFER_TOO_SMALL      Return message truncated.
        RETURN_INVALID_PARAMETER  Buffer too large
        RETURN_PROTOCOL_ERROR     Unknown error from host
 **/
RETURN_STATUS
EFIAPI
BhyveFwCtlGet (
  IN   CONST CHAR8    *Name,
  OUT  VOID        *Item,
  IN OUT  UINTN        *Size
  );

#endif