Merge tag 'trace-printf-v6.13' of git://git.kernel.org/pub/scm/linux/kernel/git/trace...
[drm/drm-misc.git] / Documentation / PCI / endpoint / pci-vntb-function.rst
blob0c51f53ab972a017c3219bf412fa02e4731f71fb
1 .. SPDX-License-Identifier: GPL-2.0
3 =================
4 PCI vNTB Function
5 =================
7 :Author: Frank Li <Frank.Li@nxp.com>
9 The difference between PCI NTB function and PCI vNTB function is
11 PCI NTB function need at two endpoint instances and connect HOST1
12 and HOST2.
14 PCI vNTB function only use one host and one endpoint(EP), use NTB
15 connect EP and PCI host
17 .. code-block:: text
20   +------------+         +---------------------------------------+
21   |            |         |                                       |
22   +------------+         |                        +--------------+
23   | NTB        |         |                        | NTB          |
24   | NetDev     |         |                        | NetDev       |
25   +------------+         |                        +--------------+
26   | NTB        |         |                        | NTB          |
27   | Transfer   |         |                        | Transfer     |
28   +------------+         |                        +--------------+
29   |            |         |                        |              |
30   |  PCI NTB   |         |                        |              |
31   |    EPF     |         |                        |              |
32   |   Driver   |         |                        | PCI Virtual  |
33   |            |         +---------------+        | NTB Driver   |
34   |            |         | PCI EP NTB    |<------>|              |
35   |            |         |  FN Driver    |        |              |
36   +------------+         +---------------+        +--------------+
37   |            |         |               |        |              |
38   |  PCI BUS   | <-----> |  PCI EP BUS   |        |  Virtual PCI |
39   |            |  PCI    |               |        |     BUS      |
40   +------------+         +---------------+--------+--------------+
41       PCI RC                        PCI EP
43 Constructs used for Implementing vNTB
44 =====================================
46         1) Config Region
47         2) Self Scratchpad Registers
48         3) Peer Scratchpad Registers
49         4) Doorbell (DB) Registers
50         5) Memory Window (MW)
53 Config Region:
54 --------------
56 It is same as PCI NTB Function driver
58 Scratchpad Registers:
59 ---------------------
61 It is appended after Config region.
63 .. code-block:: text
66   +--------------------------------------------------+ Base
67   |                                                  |
68   |                                                  |
69   |                                                  |
70   |          Common Config Register                  |
71   |                                                  |
72   |                                                  |
73   |                                                  |
74   +-----------------------+--------------------------+ Base + span_offset
75   |                       |                          |
76   |    Peer Span Space    |    Span Space            |
77   |                       |                          |
78   |                       |                          |
79   +-----------------------+--------------------------+ Base + span_offset
80   |                       |                          |      + span_count * 4
81   |                       |                          |
82   |     Span Space        |   Peer Span Space        |
83   |                       |                          |
84   +-----------------------+--------------------------+
85         Virtual PCI             Pcie Endpoint
86         NTB Driver               NTB Driver
89 Doorbell Registers:
90 -------------------
92   Doorbell Registers are used by the hosts to interrupt each other.
94 Memory Window:
95 --------------
97   Actual transfer of data between the two hosts will happen using the
98   memory window.
100 Modeling Constructs:
101 ====================
103 32-bit BARs.
105 ======  ===============
106 BAR NO  CONSTRUCTS USED
107 ======  ===============
108 BAR0    Config Region
109 BAR1    Doorbell
110 BAR2    Memory Window 1
111 BAR3    Memory Window 2
112 BAR4    Memory Window 3
113 BAR5    Memory Window 4
114 ======  ===============
116 64-bit BARs.
118 ======  ===============================
119 BAR NO  CONSTRUCTS USED
120 ======  ===============================
121 BAR0    Config Region + Scratchpad
122 BAR1
123 BAR2    Doorbell
124 BAR3
125 BAR4    Memory Window 1
126 BAR5
127 ======  ===============================