Can we use MVC instruction to move pack field to pack
field....which instruction you will use and why ?

Answers were Sorted based on User's Feedback



Can we use MVC instruction to move pack field to pack field....which instruction you will use and ..

Answer / steve holton

Qualification to above answer:

You can use MVC to move ANY data from any addressable
storage area to another. So the answer above is correct.
But if you use this technique, it is up to the programmer to
ensure that the result is valid. For example, the source
field may not be the same length as the target, so any
subsequent decimal arithmetic calculations (after a
"straight" MVC FIELD2,FIELD2) against the target field could
result in abend (S0C7). Even if the source field IS packed
decimal, if it is of a different length than the target, the
programmer will have to "adjust" the source and target
specifications to ensure that the result in the target field
is valid packed decimal. For example, if the source field is
PL3 (packed length 3)and the target is PL5, a "straight" MVC
PL5field,PL3field will leave 2 bytes of "garbage" in the
last 2 bytes of PL5field (assuming that you don't get an
abend S0C4 because the and of PL3 is at a page boundary).
For this case to work, you need MVC PL5field+2(3),PL5field,
then you need to ensure that the "top two" bytes of PL5field
are zero to ensure that subesequent packed decimal
arithmetic using PL5field will work.

Is This Answer Correct ?    14 Yes 0 No

Can we use MVC instruction to move pack field to pack field....which instruction you will use and ..

Answer / steve holton

Slight correction to above:
..."you need MVC PL5field+2(3),PL5field,..."
should read:
"you need MVC PL5field+2(3),PL3field,"
Sorry for the typo...

Is This Answer Correct ?    9 Yes 1 No

Can we use MVC instruction to move pack field to pack field....which instruction you will use and ..

Answer / rich hornak

MVC Will work but as explained you must compensate for different lengths.
The more practical instruction would be the ZAP Zero and Add Packed.

The ZAP will adjust for different lengths and propagate leading zeros when a smaller field is being moved to a larger field.

TOTAMT DC PL5'0'
NEWAMT DC PL3'0'

Current Value of TOTAMT X'453789225C'
Current Value of NEWAMT X'00100C'

ZAP Instruction
ZAP TOTAMT,NEWAMT

New Value of TOTAMT After ZAP
TOTAMT DC PL5'000000100C'

Is This Answer Correct ?    7 Yes 0 No

Can we use MVC instruction to move pack field to pack field....which instruction you will use and ..

Answer / nsugandhi

We can certainly use the MVC instruction to move the pack data to another pack field.

Is This Answer Correct ?    4 Yes 0 No

Post New Answer

More Assembler Interview Questions

what is need of start 0? In steed of

0 Answers   IBM,


about ICM instruction.

4 Answers   EDS,


Explain how to initialize a register to 0000?

0 Answers  


how to access VSAm file

2 Answers   EDS, IBM,


In the house keeping section of an MVS assembly language program, like the one below STM R14,R12,12(R13) BASR R12,R0 USING *,R12,R11 LA R11,2048 LA R11,2048(R11,R12) .... .... 1. What if BASR R12,R0 IS NOT PRECEDE USING *,R12,R11? 2. USING (base address), REGISTER does USING directive says assembler to treat particular Register as a base register with the mentioned base address..in the above case * i.e current location counter..well if that is the case why we need BASR R12,R0 ? 3. What if I write like STM R14,R12,12(R13) BASR R12,R0 LA R11,2048 LA R11,2048(R11,R12) USING *,R12,R11 there is no address resolution being calculated in both LA statements so is it a right way to set Base register?..will there be any issues with Domain regarding R11 and R12?

0 Answers  






What is base register?

23 Answers   IBM, Infosys,


What is maximum displacement?

0 Answers  


explain about maximum displacement and how to cross this limit?

0 Answers   IBM,


What does "using" do?

0 Answers  


Write the fetch cycle and execute cycle for following instructions:JMPNZ (jump to the given address if the accumulator not equal to zero) RET(return from a subroutine) ADB (add the contents of register B to the accumulator and save result in the accumulator).

1 Answers  


Explain how to pass instream data in sysin with assembler?

0 Answers  


How do you round the addition or subtraction of two numbers in assembler?

0 Answers  


Categories