360 Assembly/360 Instructions/BALR (original) (raw)
From Wikibooks, open books for an open world
BALR — Branch and Link Register — Opcode 05 / Decimal 05 — 2 byte RR Instruction.
BALR target_register,source_register (both register values are 0 to 15)
BALR 6,1
RR Instruction (2 bytes) | |||
---|---|---|---|
Byte 1bits (0-7) | Byte 2 | ||
target register(8-11) | source register (12-15) | ||
(in hex) | Opcode 05 | (4 bits)0..F / (dec 0..15) | (4 bits)0..F / (dec 0..15) |
- The first argument is a target register which value is affected by the instruction.
- The second argument is the source register.
- The target register and source register values are 0 to 15.
The BALR instruction is available on all models, 360, 370 and z/System.
BALR is a Branch and Link Register Instruction for use in transferring to different locations for code running in 24- 31, or 64-bit mode. It stores the address of the next sequential instruction in the target register, then jumps to the address specified in the source_register, unless register 0 is specified, in which case no branch is taken. This instruction remains for compatibility with 360 machines; for 370 and above, the BASR instruction is preferred.
It is used in two cases. First, to establish a base register to address locations in the current module being executed. Second, it is used to call an external routine, saving the return address. Note that when registers are used in examples, the labels R0, R1, through R15 are used to represent the values 0 or 1 through 15, respectively.
The operation of this instruction is different depending on address mode.
On 64-bit machines, the target register is loaded as follows: bits 0 to 31 are unchanged; bits 32-39 contain the instruction length code, condition cods, and program mask bits from the current PSW; bits 33 to 63 are loaded with the address of the next instruction following this one. If the source register is not 0, bits 33-63 of the source register are loaded into the PSW as the new next instruction address.
On 24- or 31-bit machines, or when operating in 24-bit mode, the target register is loaded as follows: bits 0 to 7 contain the instruction length code, condition cods, and program mask bits from the current PSW; bits 8 to 31 a loaded with the address of the next instruction following this one. If the source register is not 0, bits 8-31 of the source register are loaded into the PSW as the new next instruction address.
On 64-bit machines, the target register is loaded as follows: bits 0 to 31 are unchanged; bit 32 is set to 1; bits 33 to 63 are loaded with the address of the next instruction following this one. If the source register is not 0, bits 33-63 of the source register are loaded into the PSW as the new next instruction address.
On 31-bit machines, or when operating in 31-bit mode, the target register is loaded as follows: bit 0 is set to 1; bits 2 to 31 are loaded with the address of the next instruction following this one. If the source register is not 0, bits 2-31 of the source register are loaded into the PSW as the new next instruction address.
The address of the next instruction is loaded into bits 0-64 of the target register.
For the First example, establishing a base register, the format is
BALR R5,R0
The value of the current PC (Program Counter) plus 2 (the size of this instruction) is loaded into the target register (R5 in this case). Execution continues at the next instruction and no branch occurs.
For the Second example, calling an external routine, the format is
BALR R5,R3
It will store the Next Sequential Address after the BALR instruction in R5 and jump to the address stored in R3. R3 will have to have been preloaded before issuing this instruction with the address of the external routine, either by
- an LA or LAY instruction
- in 24- or 32-bit mode, with an L instruction of an A constant if the external routine is local to this module, or a V constant containing an external symbol if the external routine is in a different module, or
- in 64-bit mode with an LG instruction of an AD constant.
While the BALR instruction can be used for any type of subroutine call, either internal or external, when used with a non-zero source_register it primarily is used to call an external routine. The standard convention on IBM, Unisys and Fujitsu Operating Systems has been to use Register 14 as the target register, with Register 15 pre-loasded with the address of the external routine to call. Also, (in 24- and 32-bit applications) Register 13 is used to contain a 72-word storage area provided by the calling routine to allow the called routine to save Registers 14 and 0 through 12.
Typically for internal subroutines (within the same module), the BAL instruction is preferred.
The BALR instruction has no faults, however
- The target address contained within the branch register must not be odd, or an operation exception occurs
- The target address contained within the branch register must be within the range of valid memory or an operation exception occurs.
- The storage key for the target address must be the same as the current process (or this process must have a key of 0) or a memory protect violate exception occurs.
- BAL - Similar instruction usually used to call internal subroutines
- BASR - Alternative branch instruction for external subroutines on 370 or 390 machines
- BAS - Alternative internal subroutine call similar to BASR
- BSM - Used to nranch while changing the mode from 24 to 31 bit or 31 to 24 bit
- BASSM - Used to nranch while changing the mode from 24 to 31 bit or 31 to 24 bit
360 Assembly Language | |
---|---|
360 Family | Introduction · Basic FAQ · 360 Family · 360 Architecture |
360 Instruction Set | 360 Instructions · Branch Instructions · Data Transfer Instructions · Control Flow Instructions · Arithmetic Instructions · Logic Instructions · Shift and Rotate Instructions · Priveleged Instructions · Other Instructions |
Syntaxes and Assemblers | 360 Assemblers· Pseudo Instructions |
Instruction Extensions | Floating Point · High-Level Languages |