hc
2024-03-25 edb30157bad0c0001c32b854271ace01d3b9a16a
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/** @file
  Pch SATA library for CedarFork SouthCluster.
  All function in this library is available for PEI, DXE, and SMM,
  But do not support UEFI RUNTIME environment call.
 
  Copyright (c) 2019 Intel Corporation. All rights reserved. <BR>
 
  SPDX-License-Identifier: BSD-2-Clause-Patent
**/
 
#include <Base.h>
#include <Uefi/UefiBaseType.h>
#include <Library/PchInfoLib.h>
#include <PchLimits.h>
#include <Register/PchRegsSata.h>
#include <Library/SataLib.h>
 
/**
  Get Maximum Sata Controller Number
 
  @param[in] None
 
  @retval Maximum Sata Controller Number
**/
UINT8
GetPchMaxSataControllerNum (
  VOID
  )
{
  return 3;
}
 
/**
  Get Pch Maximum Sata Port Number
 
  @param[in]  SataCtrlIndex       SATA controller index
 
  @retval Pch Maximum Sata Port Number
**/
UINT8
GetPchMaxSataPortNum (
  IN UINT8      SataCtrlIndex
  )
{
  ASSERT (SataCtrlIndex < GetPchMaxSataControllerNum ());
 
  return 8;
}
 
/**
  Get SATA controller PCIe Device Number
 
  @param[in]  SataCtrlIndex       SATA controller index
 
  @retval SATA controller PCIe Device Number
**/
UINT8
GetSataPcieDeviceNum (
  IN UINT8  SataCtrlIndex
  )
{
  ASSERT (SataCtrlIndex < GetPchMaxSataControllerNum ());
 
  if (SataCtrlIndex == SATA_1_CONTROLLER_INDEX) {
    return PCI_DEVICE_NUMBER_CDF_PCH_SATA_1;
  } else if (SataCtrlIndex == SATA_2_CONTROLLER_INDEX) {
    return PCI_DEVICE_NUMBER_CDF_PCH_SATA_2;
  } else if (SataCtrlIndex == SATA_3_CONTROLLER_INDEX) {
    return PCI_DEVICE_NUMBER_CDF_PCH_SATA_3;
  } else {
    ASSERT (FALSE);
    return 0;
  }
}
 
/**
  Get SATA controller PCIe Function Number
 
  @param[in]  SataCtrlIndex       SATA controller index
 
  @retval SATA controller PCIe Function Number
**/
UINT8
GetSataPcieFunctionNum (
  IN UINT8  SataCtrlIndex
  )
{
  ASSERT (SataCtrlIndex < GetPchMaxSataControllerNum ());
 
  if (SataCtrlIndex == SATA_1_CONTROLLER_INDEX) {
    return PCI_FUNCTION_NUMBER_CDF_PCH_SATA_1;
  } else if (SataCtrlIndex == SATA_2_CONTROLLER_INDEX) {
    return PCI_FUNCTION_NUMBER_CDF_PCH_SATA_2;
  } else if (SataCtrlIndex == SATA_3_CONTROLLER_INDEX) {
    return PCI_FUNCTION_NUMBER_CDF_PCH_SATA_3;
  } else {
    ASSERT (FALSE);
    return 0;
  }
}