Commit 58b88920 authored by Jon Mason's avatar Jon Mason

NTB: Document HW errata

Add a comment describing the necessary ordering of modifications to the
NTB Limit and Base registers.
Signed-off-by: default avatarJon Mason <jon.mason@intel.com>
parent dcf81964
...@@ -689,6 +689,12 @@ static int ntb_xeon_setup(struct ntb_device *ndev) ...@@ -689,6 +689,12 @@ static int ntb_xeon_setup(struct ntb_device *ndev)
*/ */
writeq(ndev->mw[1].bar_sz + 0x1000, ndev->reg_base + writeq(ndev->mw[1].bar_sz + 0x1000, ndev->reg_base +
SNB_PBAR4LMT_OFFSET); SNB_PBAR4LMT_OFFSET);
/* HW errata on the Limit registers. They can only be
* written when the base register is 4GB aligned and
* < 32bit. This should already be the case based on the
* driver defaults, but write the Limit registers first
* just in case.
*/
} else { } else {
ndev->limits.max_mw = SNB_MAX_MW; ndev->limits.max_mw = SNB_MAX_MW;
...@@ -707,6 +713,12 @@ static int ntb_xeon_setup(struct ntb_device *ndev) ...@@ -707,6 +713,12 @@ static int ntb_xeon_setup(struct ntb_device *ndev)
* something silly * something silly
*/ */
writeq(0, ndev->reg_base + SNB_PBAR4LMT_OFFSET); writeq(0, ndev->reg_base + SNB_PBAR4LMT_OFFSET);
/* HW errata on the Limit registers. They can only be
* written when the base register is 4GB aligned and
* < 32bit. This should already be the case based on the
* driver defaults, but write the Limit registers first
* just in case.
*/
} }
/* The Xeon errata workaround requires setting SBAR Base /* The Xeon errata workaround requires setting SBAR Base
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment