summaryrefslogtreecommitdiffstats
path: root/QuarkSocPkg/QuarkNorthCluster/QNCInit/Dxe/QNCRootPorts.c
blob: e87d1f45fc27110442da7e4d7aef3de6f776d927 (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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/** @file
PciHostBridge driver module, part of QNC module.

Provides the basic interfaces to abstract a PCI Host Bridge Resource Allocation.

Copyright (c) 2013-2015 Intel Corporation.

This program and the accompanying materials
are licensed and made available under the terms and conditions of the BSD License
which accompanies this distribution.  The full text of the license may be found at
http://opensource.org/licenses/bsd-license.php

THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.

**/
#include "CommonHeader.h"
#include "QNCInit.h"

UINT32  mS3ParameterRootPortDownstream = 0;
EFI_QNC_S3_DISPATCH_ITEM  mS3DispatchItem = {
    QncS3ItemTypeInitPcieRootPortDownstream,
    &mS3ParameterRootPortDownstream
  };

EFI_STATUS
QncInitRootPorts (
  )
/*++

Routine Description:

  Perform Initialization of the Downstream Root Ports

Arguments:

Returns:

  EFI_SUCCESS             The function completed successfully

--*/
{
  EFI_STATUS                   Status;
  EFI_QNC_S3_SUPPORT_PROTOCOL  *QncS3Support;
  VOID                         *Context;
  VOID                         *S3DispatchEntryPoint;

  Status = PciExpressInit ();
  ASSERT_EFI_ERROR (Status);

  //
  // Get the QNC S3 Support Protocol
  //
  Status = gBS->LocateProtocol (
                  &gEfiQncS3SupportProtocolGuid,
                  NULL,
                  (VOID **) &QncS3Support
                  );
  ASSERT_EFI_ERROR (Status);
  if (EFI_ERROR (Status)) {
    return Status;
  }

  //
  // Get the QNC S3 Support Protocol
  //
  Status = QncS3Support->SetDispatchItem (
                          QncS3Support,
                          &mS3DispatchItem,
                          &S3DispatchEntryPoint,
                          &Context
                          );
  ASSERT_EFI_ERROR (Status);

  //
  // Save the script dispatch item in the Boot Script
  //
  Status = S3BootScriptSaveDispatch2 (S3DispatchEntryPoint, Context);
  ASSERT_EFI_ERROR (Status);

  return Status;
}