Встроенное ожидание с помощью MASM - PullRequest
1 голос
/ 26 октября 2009

Как конвертировать это для использования VC ++ и MASM

static __inline__ void io_wait(void)
{
  asm volatile("jmp 1f;1:jmp 1f;1:");
}

Я знаю, что asm изменяется на __asm, и мы удаляем изменчивый, но что дальше?

Я пытаюсь создать функцию для размещения в коде ниже

#define PIC1        0x20
#define PIC2        0xA0
#define PIC1_COMMAND    PIC1
#define PIC1_DATA   (PIC1+1)
#define PIC2_COMMAND    PIC2
#define PIC2_DATA   (PIC2+1)
#define PIC_EOI     0x20

#define ICW1_ICW4   0x01        /* ICW4 (not) needed */
#define ICW1_SINGLE 0x02        /* Single (cascade) mode */
#define ICW1_INTERVAL4  0x04        /* Call address interval 4 (8) */
#define ICW1_LEVEL  0x08        /* Level triggered (edge) mode */
#define ICW1_INIT   0x10        /* Initialization - required! */

#define ICW4_8086   0x01        /* 8086/88 (MCS-80/85) mode */
#define ICW4_AUTO   0x02        /* Auto (normal) EOI */
#define ICW4_BUF_SLAVE  0x08        /* Buffered mode/slave */
#define ICW4_BUF_MASTER 0x0C        /* Buffered mode/master */
#define ICW4_SFNM   0x10        /* Special fully nested (not) */

void remap_pics(int pic1, int pic2)
{
    UCHAR   a1, a2;

    a1=ReadPort8(PIC1_DATA);
    a2=ReadPort8(PIC2_DATA);

    WritePort8(PIC1_COMMAND, ICW1_INIT+ICW1_ICW4);
    io_wait();
    WritePort8(PIC2_COMMAND, ICW1_INIT+ICW1_ICW4);
    io_wait();
    WritePort8(PIC1_DATA, pic1);
    io_wait();
    WritePort8(PIC2_DATA, pic2);
    io_wait();
    WritePort8(PIC1_DATA, 4);
    io_wait();
    WritePort8(PIC2_DATA, 2);
    io_wait();

    WritePort8(PIC1_DATA, ICW4_8086);
    io_wait();
    WritePort8(PIC2_DATA, ICW4_8086);
    io_wait();

    WritePort8(PIC1_DATA, a1);
    WritePort8(PIC2_DATA, a2);
}

Ответы [ 2 ]

1 голос
/ 26 октября 2009

Думаю, вам повезет больше, если вы расскажете нам, что вы пытаетесь сделать с этим кодом. Ни одна из платформ, поддерживаемых VC ++, не будет ожидать завершения ввода-вывода, выполняя безусловный переход.

Тем не менее, учитывая ваш пример, я вижу несколько проблем, которые вам нужно решить в первую очередь:

  1. «1f» должен иметь суффикс, указывающий, что он шестнадцатеричный. В VC ++ вы можете использовать суффиксы стиля C (0x1f) или стиля сборки (1fh) во встроенной сборке
  2. похоже, у вас есть две метки "1". Помимо того, что две метки с одинаковыми именами будут сталкиваться, я считаю, что VC ++ не поддерживает имена меток, содержащие только цифры
  3. 1fh - странный адрес для перехода. В реальном режиме это область IRQ, в защищенном режиме она находится на первой странице, которую большинство операционных систем не отображает, чтобы отследить разыменование NULL.

За исключением этого, ваш код, который можно перевести на VC ++, должен выглядеть следующим образом:

__asm {
    jmp 1fh
a1:
    jmp 1fh
b1:
}

Но это не принесет вам ничего полезного. Поэтому, пожалуйста, укажите, чего вы пытаетесь достичь

0 голосов
/ 26 декабря 2018

Кажется, что синтаксис газа GNU, jmp 1f означает переход к метке 1 вперед.

static __inline__ void io_wait(void)
{
#ifdef __GNUC__
  asm volatile("jmp 1f;1:jmp 1f;1:");
#else
  /* MSVC x86 supports inline asm */
  __asm {
    jmp a1
  a1:
    jmp b1
  b1:
  }
#endif
}
...