Variant:
The Surface Update component provides a communication channel interface for use by components that render graphics content to
The client renders the graphics content to a buffer within the surface and then sends a request for composition. The request includes the surface ID, the ID of the current buffer within the surface and optionally the following:
The number of the screen on which the surface is to be displayed. Alternatively, the
The region of the surface that has changed. This is sometimes referred to as the dirty rectangle. If the client does not specify this, the whole surface is recomposed.
The client can request notification of the following composition-related events:
The buffer has become available for rendering.
The buffer has been displayed for the first time after the update was submitted. This notification is accompanied by timestamp information.
The buffer has been displayed a certain number of times. This can be used to ensure that each frame gets displayed for at least a given period of time.
The Surface Update component is an adaptation component, which means that it can be replaced by device creators to suit the exact hardware. The reference implementation consists of the Surface Update Server and its client-side API. The Surface Update Server runs within the Window Server process along with the composition engine. The Surface Update Server uses the standard Symbian client/server model for Inter Process Communication (IPC) to communicate with clients and Inter Thread Communication (using active objects and semaphores) to communicate with the composition engine.
The client sends requests for composition through the command channel and the composition engine sends notification messages through the notification channel.
The following diagram shows communication between the client, Surface Update server and composition engine. The composition engine is shown as a single component, although it can be implemented as multiple components. For example, the
Some key points to note include:
The composition engine is a device-specific adaptation that may delegate some of its functionality (such as composing hardware-rendered surfaces) to a GPU or display controller.
There is a composition engine instance for each internal screen and external screen connection point on the device. Each composition engine must be registered with the Surface Update Server at startup.
Each composition engine instance has a unique 32-bit priority number, which represents the relative priority of its associated screen. The higher the number, the higher the priority of the screen. The composition engine instance passes this to the Surface Update Server at registration. The Surface Update Server adds the priority value to its priority list. After it is set up, the priority list is fixed and does not change when a screen becomes unavailable—for example, because it is put on standby or an external screen is disconnected.
Each composition engine instance incorporates its own thread within the Window Server process. However, the external interface is accessed directly from the thread that makes the call. This means that
The Window Server's main thread is a client of the Surface Update Server. Although it is running in the same process as the Surface Update Server, it uses
The following diagram provides a more detailed view of the architecture. Notice that there is a composition engine thread for each screen.
Do not confuse the Surface Update Server with the
Here is a simplified
To use the API:
Connect to the Surface Update Server.
Set up one or more notification requests.
This part of the process is optional. You need to do it only if the client wants to know when the composition engine has used the data on the surface. To set up a request, call one of the
Send notification that your surface data has been updated.
Call the
Wait for notifications from the Surface Update Server.
If the client requests notification(s), it must wait (
Close the connection.
If your client is still waiting for a notification you must call
Example
Here is a snippet of test code which illustrates the process of setting up notification requests before submitting an update. This piece of code results in four messages being sent to the Surface Update Server in
Notes:
Because this is test code and to avoid complexity, this example calls
In some hardware configurations where composition and display are fast, the buffer available and first displayed notifications may occur very close together for single-buffered surfaces. You should then use only one of these notifications at a time.
These sequence diagrams primarily illustrate the protocol linking the sending of the buffers and notification. For simplicity some detail is omitted. For example, the client typically renders to the buffer before sending it to the composition engine. This is not shown. Similarly the diagrams omit detail from the composition engine and some omit the Surface Update Server altogether. In addition, they assume that a specific screen number is specified. When global surface updates are in use, the sequence is more complex and is described in
Surface buffer availability: single-buffered surface
When using a single-buffered surface, the client typically does the following:
Render the graphics content to the buffer.
Call
Call
Wait for notification that the buffer is available before rendering further content to it and repeating the cycle for as long as necessary.
This is shown in the following diagram.
Notice that the notification signal is issued to the client immediately after the buffer has been consumed by the composition engine. When single buffers are used, tearing artefacts are always a risk. Therefore double-buffered surfaces are often used.
Surface buffer availability: double-buffered surface
When double-buffering is used, the client renders to one buffer (called A in this example) while the other buffer (B) is on the screen and vice versa. In order for this to work correctly and to be free of tearing artefacts, the client must use the following sequence:
Render the graphics content to buffer A, and call
Render the graphics content to buffer B, and call
Wait for notification that buffer A is available. When it becomes available, render further content to it and call
Wait for notification that buffer B is available. When it becomes available, render further content to it and call
Repeat steps 3 and 4 for as long as required.
This is shown in the next diagram. After sending the first two buffers to the composition engine, the client waits for notification before sending a further buffer. The composition engine always returns notification after receiving a new buffer even if an error condition is detected.
Notes:
The buffer that is on the screen is called the front buffer and the one that is being rendered into is called the back buffer.
Although double-buffering is shown, three or more buffers can be used.
Frame update
The following diagram shows the sequence when a client submits a request to be notified when the buffer has been displayed three times. However, the exact details depend on how the composition engine is implemented. If the composition engine knows the screen refresh rate, it can post the composed buffer to the Display Driver and wait for notification that the buffer is on the screen. It could then uses a timer to wait for three frames to be displayed, before it sends the notification.
If the client sends a new request for update while the previous one is still in progress, the previous request is cancelled with the
Cancelling of all outstanding requests
If the client is waiting for a notification when you need to remove the active object that is handling the notification and close the thread, you must call
However,
Variant:
The Surface Update component provides a communication channel interface for use by components that render graphics content to
The client renders the graphics content to a buffer within the surface and then sends a request for composition. The request includes the surface ID, the ID of the current buffer within the surface and optionally the following:
The number of the screen on which the surface is to be displayed. Alternatively, the
The region of the surface that has changed. This is sometimes referred to as the dirty rectangle. If the client does not specify this, the whole surface is recomposed.
The client can request notification of the following composition-related events:
The buffer has become available for rendering.
The buffer has been displayed for the first time after the update was submitted. This notification is accompanied by timestamp information.
The buffer has been displayed a certain number of times. This can be used to ensure that each frame gets displayed for at least a given period of time.
The Surface Update component is an adaptation component, which means that it can be replaced by device creators to suit the exact hardware. The reference implementation consists of the Surface Update Server and its client-side API. The Surface Update Server runs within the Window Server process along with the composition engine. The Surface Update Server uses the standard Symbian client/server model for Inter Process Communication (IPC) to communicate with clients and Inter Thread Communication (using active objects and semaphores) to communicate with the composition engine.
The client sends requests for composition through the command channel and the composition engine sends notification messages through the notification channel.
The following diagram shows communication between the client, Surface Update server and composition engine. The composition engine is shown as a single component, although it can be implemented as multiple components. For example, the
Some key points to note include:
The composition engine is a device-specific adaptation that may delegate some of its functionality (such as composing hardware-rendered surfaces) to a GPU or display controller.
There is a composition engine instance for each internal screen and external screen connection point on the device. Each composition engine must be registered with the Surface Update Server at startup.
Each composition engine instance has a unique 32-bit priority number, which represents the relative priority of its associated screen. The higher the number, the higher the priority of the screen. The composition engine instance passes this to the Surface Update Server at registration. The Surface Update Server adds the priority value to its priority list. After it is set up, the priority list is fixed and does not change when a screen becomes unavailable—for example, because it is put on standby or an external screen is disconnected.
Each composition engine instance incorporates its own thread within the Window Server process. However, the external interface is accessed directly from the thread that makes the call. This means that
The Window Server's main thread is a client of the Surface Update Server. Although it is running in the same process as the Surface Update Server, it uses
The following diagram provides a more detailed view of the architecture. Notice that there is a composition engine thread for each screen.
Do not confuse the Surface Update Server with the
Here is a simplified
To use the API:
Connect to the Surface Update Server.
Set up one or more notification requests.
This part of the process is optional. You need to do it only if the client wants to know when the composition engine has used the data on the surface. To set up a request, call one of the
Send notification that your surface data has been updated.
Call the
Wait for notifications from the Surface Update Server.
If the client requests notification(s), it must wait (
Close the connection.
If your client is still waiting for a notification you must call
Example
Here is a snippet of test code which illustrates the process of setting up notification requests before submitting an update. This piece of code results in four messages being sent to the Surface Update Server in
Notes:
Because this is test code and to avoid complexity, this example calls
In some hardware configurations where composition and display are fast, the buffer available and first displayed notifications may occur very close together for single-buffered surfaces. You should then use only one of these notifications at a time.
These sequence diagrams primarily illustrate the protocol linking the sending of the buffers and notification. For simplicity some detail is omitted. For example, the client typically renders to the buffer before sending it to the composition engine. This is not shown. Similarly the diagrams omit detail from the composition engine and some omit the Surface Update Server altogether. In addition, they assume that a specific screen number is specified. When global surface updates are in use, the sequence is more complex and is described in
Surface buffer availability: single-buffered surface
When using a single-buffered surface, the client typically does the following:
Render the graphics content to the buffer.
Call
Call
Wait for notification that the buffer is available before rendering further content to it and repeating the cycle for as long as necessary.
This is shown in the following diagram.
Notice that the notification signal is issued to the client immediately after the buffer has been consumed by the composition engine. When single buffers are used, tearing artefacts are always a risk. Therefore double-buffered surfaces are often used.
Surface buffer availability: double-buffered surface
When double-buffering is used, the client renders to one buffer (called A in this example) while the other buffer (B) is on the screen and vice versa. In order for this to work correctly and to be free of tearing artefacts, the client must use the following sequence:
Render the graphics content to buffer A, and call
Render the graphics content to buffer B, and call
Wait for notification that buffer A is available. When it becomes available, render further content to it and call
Wait for notification that buffer B is available. When it becomes available, render further content to it and call
Repeat steps 3 and 4 for as long as required.
This is shown in the next diagram. After sending the first two buffers to the composition engine, the client waits for notification before sending a further buffer. The composition engine always returns notification after receiving a new buffer even if an error condition is detected.
Notes:
The buffer that is on the screen is called the front buffer and the one that is being rendered into is called the back buffer.
Although double-buffering is shown, three or more buffers can be used.
Frame update
The following diagram shows the sequence when a client submits a request to be notified when the buffer has been displayed three times. However, the exact details depend on how the composition engine is implemented. If the composition engine knows the screen refresh rate, it can post the composed buffer to the Display Driver and wait for notification that the buffer is on the screen. It could then uses a timer to wait for three frames to be displayed, before it sends the notification.
If the client sends a new request for update while the previous one is still in progress, the previous request is cancelled with the
Cancelling of all outstanding requests
If the client is waiting for a notification when you need to remove the active object that is handling the notification and close the thread, you must call
However,