GCSSS1, Guarded Control Stack Switch Stack 1

The GCSSS1 characteristics are:

Purpose

Validates that the stack being switched to contains a Valid cap entry, stores an In-progress cap entry on to the stack that is getting switched to and sets the current Guarded Control Stack Pointer to the stack that is getting switched to.

Configuration

This instruction is present only when FEAT_GCS is implemented. Otherwise, direct accesses to GCSSS1 are UNDEFINED.

Attributes

GCSSS1 is a 64-bit System instruction.

Field descriptions

6362616059585756555453525150494847464544434241403938373635343332
313029282726252423222120191817161514131211109876543210
Input address, for the incoming Guarded Control Stack
Input address, for the incoming Guarded Control Stack

Bits [63:0]

Input address, for the incoming Guarded Control Stack.

Executing GCSSS1

Accesses to this instruction use the following encodings in the System instruction encoding space:

GCSSS1 <Xt>

op0op1CRnCRmop2
0b010b0110b01110b01110b010

if PSTATE.EL == EL0 then GCSSS1(X[t, 64]); elsif PSTATE.EL == EL1 then GCSSS1(X[t, 64]); elsif PSTATE.EL == EL2 then GCSSS1(X[t, 64]); elsif PSTATE.EL == EL3 then GCSSS1(X[t, 64]);


26/03/2024 09:49; 67c0ae5282a7629ba0ea0ba7267b43cd4f7939f6

Copyright © 2010-2024 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.