diff --git a/doc/specs/#5000 - Process Model 2.0/#5000 - Process Model 2.0.md b/doc/specs/#5000 - Process Model 2.0/#5000 - Process Model 2.0.md
index d4b9bd2d107..cb48577c663 100644
--- a/doc/specs/#5000 - Process Model 2.0/#5000 - Process Model 2.0.md
+++ b/doc/specs/#5000 - Process Model 2.0/#5000 - Process Model 2.0.md
@@ -1,7 +1,7 @@
---
author: Mike Griese @zadjii-msft
created on: 2020-07-31
-last updated: 2020-08-07
+last updated: 2020-08-10
issue id: #5000
---
@@ -89,6 +89,17 @@ to connect to and display content that's being hosted in another process.
### Window and Content Processes
+To begin, let's first take a look at a rough diagram of how the Windows Terminal
+process looks today:
+
+data:image/s3,"s3://crabby-images/1b2bd/1b2bdfc3ee38199dad42638f3a46b37264524acc" alt="figure-001"
+
+Currently, the entire Windows Terminal exists as a single process composed of
+many parts. it has a top Win32 layer responsible for the window, which includes
+a UWP XAML-like App layer, which embeds many `TermControl`s, each of which
+contains the buffer and renderer, and communicates with a connection to another
+process.
+
The primary concept introduced by this spec is the idea of two types of process,
which will work together to create a single Terminal window. These processes
will be referred to as the "Window Process" and the "Content Process".
@@ -112,6 +123,8 @@ These thin `TermControl`s will recieve input, and have all the UI elements
_rendering_ to the swap chain, and the handling of those inputs will be done by
the content process.
+data:image/s3,"s3://crabby-images/de9f6/de9f6a6d17864c7d062a7b8b8ee49ca6e0aaf382" alt="figure-002"
+
As a broad outline, whenever the window wants to create a terminal, the flow
will be something like the following:
@@ -126,6 +139,8 @@ will be something like the following:
process's `SwapChainPanel`, because they share the same underlying kernel
object.
+data:image/s3,"s3://crabby-images/73b39/73b39423b72302efc4b0db1e6d6c3563bd88b291" alt="figure-003"
+
The content process will be responsible for the terminal buffer and other
terminal state (the core `Terminal` object), as well as the `Renderer`,
`DxEngine`, and `TerminalConnection`. These are all being combined in the
@@ -136,6 +151,7 @@ the connection as quickly as possible, and the best way to do this will be to
have the connection in the same process as the `Terminal` core.
+
#### Technical Details
Much of the above is powered by the magic of WinRT (which is powered by the
@@ -182,7 +198,7 @@ This means that if we wanted to have a second window process connect to the
_same_ content process as another window, all it needs is the content process's
GUID.
-#### Scenario: Tab Tearoff/ Reattach
+#### Scenario: Tab Tear-off and Reattach
Because all that's needed to uniquely identify an individual terminal instance
is the GUID of the content process, it becomes fairly trivial to be able to
@@ -545,33 +561,114 @@ of the initial release of tab tearout.
Accessibility |
-TODO: This is _very_ applicable
+
+When working on the implementation of the window/content process split, we'll
+need to ensure that the contents of the buffer are still readable by
+accessibility tools like Narrator and NVDA. We'll be moving the actual buffer
+out of the window process into the content process, so we'll need to make sure
+that we can hook up the `TermControlAutomationPeer` across the process boundary.
+Presumably, this is possible trivially because it's already implemented as a
+WinRT type.
+
+I'll be especially curious to make sure that
+`TermControl::OnCreateAutomationPeer` can occur off the window process's UI
+thread, because all cross-process calls will need to happen off the UI thread.
+
|
Security |
-TODO: This is _very_ applicable
+
+As we'll be introducing a mechanism for crossing elevation boundaries, we'll
+want to be especially careful as we make these changes.
+
+Our biggest concern regarding mixed elevation was regarding the ability for a
+non-elevated process to send input to another unelevated WT window, which was
+connected to an elevated client process. With these proposed changes, we won't
+have any unelevated windows connected to unelevated processes, so that concern
+should be mitigated.
+
+Additionally, we'll probably want to make sure that the user is visually
+prompted when a connection to an elevated client is initiated. Typically, this
+is done with a UAC prompt, which seems reasonable in this scenario as well.
+
+We'll likely want to default elevated windows to spawning unelevated
+connections, as to prevent accidentally running connections as an administrator.
+This is in contrast to existing behavior, where all connections in an elevated
+WT window are elevated.
+
+Furthermore, we'll want to ensure that there's nothing that an unelevated client
+process could do to trigger any sort of input callback in the parent window. If
+the parent window is an elevated window, with other elevated connections, then
+we don't want the uelevated content process to act as a vector by which
+malicious software could hijack the elevated window.
+
|
Reliability |
-TODO: This is _very_ applicable
+
+This is probably the biggest concern in this section. Because there will now be
+many, many more processes in the process tree, it is imperitive that whenever
+we're doing cross-process operations, we do them safely.
+
+Whenever we're working with an object that's hosted by another process, we'll
+need to make sure that we work with it in a try/catch, because at _any_ time,
+the other process could be killed. At any point, a content process could be
+killed, without the window being closed. The window will need to be redundant to
+such a scenario, and if the content process is killed, display an appropriate
+error message, but _continue running_.
+
+When the monarch process dies, we'll need to be able to reliably elect a new
+monarch. While we're electing a new monarch, and updating the new monarch,
+there's always the chance that the _new_ monarch is also killed (This is the
+"Pope Stephen II" scenario). In this sccenario, if at any point a servant
+notices that the monarch has died, the servant will need to begin checking who
+the new monarch is again.
+
+There is certain to be a long tail of edge cases we'll discover as a product of
+this change. We'll need to be prepared to see an inevitable decrease in initial
+reliability numbers, and increased bug reports for a time. Additionally, these
+bug will likely be fairly difficult to track down.
+
+In the long run, this may end up _increasing_ reliability, as crashes in the
+buffer should no longer cause the _entire_ terminal application to crash.
+
+
|
Compatibility |
-TODO: This is _very_ applicable
-TODO: Concerns with the Universal App version of the Terminal?
+The biggest concern regarding compatibility will be ensuring that the Universal
+app version of the Windows Terminal will still work as before. Although that
+application isn't used by any customer-facing scenarios currently, it still
+represents some long term goals for the Terminal. We'll probably need to
+disable tearout _entirely_ on the universal app, at least to begin with.
+Additionally, we'll need to ensure that all the controls in the universal
+application are in-proc controls, not using the window/content split process
+model.
+
+I'm also concerned that each individual atomic step along the path towards this
+goal still works. For more on this topic, see [Implementation
+Plan](#implementation-plan).
+
|
Performance, Power, and Efficiency |
-TODO: This is _very_ applicable
+
+There's no dramatic change expected here. There may be a minor delay in the
+spawning of new terminal instances, due to requiring cross-process hops for the
+instantiation of the content process.
+
+Additionally, minor delays are expected to be introduced during startup for the
+initial setup of the monarch/servant relationship.
+
|
diff --git a/doc/specs/#5000 - Process Model 2.0/figure-001.png b/doc/specs/#5000 - Process Model 2.0/figure-001.png
new file mode 100644
index 00000000000..088a95457a8
Binary files /dev/null and b/doc/specs/#5000 - Process Model 2.0/figure-001.png differ
diff --git a/doc/specs/#5000 - Process Model 2.0/figure-002.png b/doc/specs/#5000 - Process Model 2.0/figure-002.png
new file mode 100644
index 00000000000..5b8120bba11
Binary files /dev/null and b/doc/specs/#5000 - Process Model 2.0/figure-002.png differ
diff --git a/doc/specs/#5000 - Process Model 2.0/figure-003.png b/doc/specs/#5000 - Process Model 2.0/figure-003.png
new file mode 100644
index 00000000000..7d8af33e8c4
Binary files /dev/null and b/doc/specs/#5000 - Process Model 2.0/figure-003.png differ