сдвиньте влево один раз и получите значение из переноса - PullRequest
2 голосов
/ 16 мая 2011

Я использую версию микрочипа v8.63 с компилятором C.

Следующий фрагмент кода, я хочу «сдвинуть значение 1206420333240d», я знаю, что 1 бит поступает в регистр переноса,Но я не знаю, как получить эти значения на ассемблере для pic18F4550.Мой вопрос, как я могу сместиться один раз с ассемблером для рис 18F4550 и получить значение из переноса?

В комплекте весь проект.

unsigned int rood = 1206420333240;


void main (void)
{   
    //int rood[] = {0,0,1,0,1,0,1,0,1,0,1,1,1,0,0,0,0,1,1,0,1,0,1,0,1,0,0,0,1,1,0,1,1,1,0,1,0,1,0,1,0,0,0,1,1};

    TRISD = 0x00;               // PORTD  als output
    TRISB = 0b00110000;         // RB4 en RB5 als input
    TRISA = 0x00;               // RA output

    RCONbits.IPEN = 0;          // prioriteit disable
    INTCONbits.GIE = 1;         // enable interrupt
    INTCONbits.RBIE = 1;        // interrupt portB on

    while(1)
    {   
        _asm sleep _endasm  
    }
}

#pragma interrupt ISR
void ISR (void)
{


    if (INTCONbits.RBIF==1)
    {
        if(PORTBbits.RB5==0)        // S3 pressed ?
        {
            int i = 0;
            int b;
            do {
                // Try to shift left (SHF) and get value in carry.
                _asm
                    mov  EAX, 1206420333240d
                _endasm
                //LATAbits.LATA2 = rood << 1;
                //LATDbits.LATD1 ^= 1;

                //do-while for the frequentie (1500 is de freq)
                b = 0;
                do {
                    b++;
                }while(b <= 2000);

                i++;
            }while(sizeof(rood) <= 50);

            //LATDbits.LATD1 ^= 1;      // D2 togglen

        }

    }   
    INTCONbits.RBIF = 0;
}

1 Ответ

2 голосов
/ 16 мая 2011

Если используется PIC 18 сборка , то есть одна команда, которая повернет левое значение и сохранит бит переноса в назначенном регистре.

RLCF REG, 0, 0

(см. Стр. 243 в приведенном выше связанном документе). Примечание: вам нужно будет опросить регистр переноса, чтобы получить значение и, возможно, установить младший значащий бит в «0», чтобы противодействовать операции поворота и превратить его в операцию сдвига.

Вы можете прибегнуть к встроенной сборке, чтобы выполнить это, однако мне интересно, почему следующее не сработает:

int carry = (value & 0X80) >> 7; // substitute the correct bit masks here
value = value << 1;

if( carry == 1 )
{
    // Perform action
}
...