Зсуви та циклічні зсуви
У процесорах 8086 існує множина способів, за допомогою яких можна зсувати біти регістра чи змінної у пам’яті вліво чи вправо. Найпростішим з них є логічний зсув. Інструкція SHL (зсув ліворуч, синонім – SAL) переміщує кожний біт операнда-приймача на один розряд вліво, у напрямку до самого значущого біту. Наприклад значення 10010110b (96h чи 150 у десятковій уяві) записане у AL, зсувається вліво за допомогою інструкції SHL AL,1. В результаті виходить значення 00101100b (24Ch чи 44 у десятковій уяві), яке записується назад у регістр AL. Флаг переносу встановлюється в значення 1. Інструкція SAR (арифметичний зсув праворуч) аналогічна інструкції SHR, тільки при її виконанні найбільш значущий біт операнда зсувається праворуч у наступний біт, а потім копіюється назад. Наприклад значення 10010110b (96h чи –106 у десятковій уяві зі знаком), записане у регістрі AL зсувається праворуч за допомогою інструкції SAR AL,1. В результаті виходить значення 11001011b (0CBh чи –53 у десятковій уяві зі знаком), яке записується назад у регістр AL. Флаг переносу встановлюється у значення 0. Операція ROL має дію, зворотну дії операції ROR. Операнд також зсувається циклічно, але зсув виконується ліворуч. При цьому найбільш значущий біт зсувається у найменш значущий. Інструкції ROR та ROL корисно використовувати для пере упорядковування біт у байті чи у слові. Наприклад, в результаті виконання інструкцій:
mov si,49F1h mov cl,4 ror si,cl у регістр SI буде записано значення 149Fh: біти 3-0 перемістяться в біти 15-12, біти 7-4 – в біти 3-0 і т.д. Інструкції RCR та RCL працюють трохи по-іншому. Інструкція RCR аналогічно інструкції зсуву праворуч, при цьому найбільш значущий біт зсувається з флага переносу. Наприклад значення 10010110b (96h чи 150 у десятковій уяві), записане у регістрі AL, циклічно зсувається праворуч через флаг переносу, початкове значення якого дорівнює 1, за допомогою інструкції RCR AL,1. В результаті отримуємо значення 1100101b (0CBh чи 203 у десятковій уяві), яке записується назад у регістр AL. Флаг переносу встановлюється у значення 0. Інструкція RCL аналогічно, відповідно, лівому зсуву. При виконанні цієї інструкції найменш значущий біт зсувається з флага переносу. Інструкції RCR та RCL корисно використовувати для зсуву операнда, який складається з декількох слів. Наприклад, наступні інструкції виконують множення значення у DX:AX, розміром у подвійне слово на 4:
shl ax,1; біт 15 регістру AX зсувається у флаг переносу rcl dx,1; флаг переносу зсувається у біт 0 регістру DX shl ax,1; біт 15 регістру AX зсувається у флаг переносу rcl dx,1; флаг переносу зсувається у біт 0 регістру DX.
Інструкції циклічного зсуву, аналогічно інструкціям зсуву, можуть зсовувати операнд на 1 біт чи на число біт, заданих регістром CL.
|