⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bsp.c

📁 事件驱动程序设计很好的框架
💻 C
字号:
/****************************************************************************** Product: DPP example, 80x86, Vanilla/DOS, Turbo C++ 1.01* Last Updated for Version: 4.0.00* Date of the Last Update:  Apr 07, 2008**                    Q u a n t u m     L e a P s*                    ---------------------------*                    innovating embedded systems** Copyright (C) 2002-2008 Quantum Leaps, LLC. All rights reserved.** This software may be distributed and modified under the terms of the GNU* General Public License version 2 (GPL) as published by the Free Software* Foundation and appearing in the file GPL.TXT included in the packaging of* this file. Please note that GPL Section 2[b] requires that all works based* on this software must also be made publicly available under the terms of* the GPL ("Copyleft").** Alternatively, this software may be distributed and modified under the* terms of Quantum Leaps commercial licenses, which expressly supersede* the GPL and are specifically designed for licensees interested in* retaining the proprietary status of their code.** Contact information:* Quantum Leaps Web site:  http://www.quantum-leaps.com* e-mail:                  info@quantum-leaps.com*****************************************************************************/#include "qp_port.h"#include "dpp.h"#include "bsp.h"#include <conio.h>#include <stdlib.h>#include <stdio.h>#include <time.h>Q_DEFINE_THIS_FILE/* Local-scope objects -----------------------------------------------------*/static void interrupt (*l_dosTmrISR)();static void interrupt (*l_dosKbdISR)();static uint32_t l_delay = 0UL; /* limit for the loop counter in busyDelay() */#ifdef Q_SPY    static uint16_t l_uart_base;        /* QS data uplink UART base address */    static QSTimeCtr l_tickTime;                 /* keeps timetsamp at tick */    #define UART_16550_TXFIFO_DEPTH 16    enum AppRecords {                 /* application-specific trace records */        PHILO_STAT = QS_USER    };#endif#define TMR_VECTOR      0x08#define KBD_VECTOR      0x09/*..........................................................................*/void interrupt ISR_tmr(void) {    QF_INT_UNLOCK(dummy);                              /* unlock interrupts */    QF_tick();                /* call QF_tick() outside of critical section */#ifdef Q_SPY    l_tickTime += 0x10000;                           /* add 16-bit rollover */#endif    QF_INT_LOCK(dummy);                            /* lock interrupts again */    outportb(0x20, 0x20);              /* write EOI to the master 8259A PIC */}/*..........................................................................*/void interrupt ISR_kbd(void) {    uint8_t key;    uint8_t kcr;    QF_INT_UNLOCK(dummy);                              /* unlock interrupts */    key = inport(0x60);        /*key scan code from the 8042 kbd controller */    kcr = inport(0x61);                    /* get keyboard control register */    outportb(0x61, (uint8_t)(kcr | 0x80));   /* toggle acknowledge bit high */    outportb(0x61, kcr);                      /* toggle acknowledge bit low */    if (key == (uint8_t)129) {                          /* ESC key pressed? */        static QEvent term = {TERMINATE_SIG, 0};            /* static event */        QF_publish(&term);                 /* publish to all interested AOs */    }    QF_INT_LOCK(dummy);                            /* lock interrupts again */    outportb(0x20, 0x20);              /* write EOI to the master 8259A PIC */}/*..........................................................................*/void QF_onStartup(void) {                                      /* save the origingal DOS vectors ... */    l_dosTmrISR = getvect(TMR_VECTOR);    l_dosKbdISR = getvect(KBD_VECTOR);    QF_INT_LOCK(dummy);    setvect(TMR_VECTOR, &ISR_tmr);    setvect(KBD_VECTOR, &ISR_kbd);    QF_INT_UNLOCK(dummy);}/*..........................................................................*/void QF_onCleanup(void) {           /* restore the original DOS vectors ... */    QF_INT_LOCK(dummy);    setvect(TMR_VECTOR, l_dosTmrISR);    setvect(KBD_VECTOR, l_dosKbdISR);    QF_INT_UNLOCK(dummy);    QS_EXIT();                                                   /* exit QS */    _exit(0);                                                /* exit to DOS */}/*..........................................................................*/void QF_onIdle(void) {                     /* called with interrupts LOCKED */    QF_INT_UNLOCK(dummy);                       /* always unlock interrupts */#ifdef Q_SPY    if ((inportb(l_uart_base + 5) & (1 << 5)) != 0) {         /* THR empty? */        uint16_t fifo = UART_16550_TXFIFO_DEPTH;     /* 16550 Tx FIFO depth */        uint8_t const *block;        QF_INT_LOCK(dummy);        block = QS_getBlock(&fifo);    /* try to get next block to transmit */        QF_INT_UNLOCK(dummy);        while (fifo-- != 0) {                    /* any bytes in the block? */            outportb(l_uart_base + 0, *block++);        }    }#endif}/*..........................................................................*/void BSP_init(int argc, char *argv[]) {    char const *com = "COM1";    if (argc > 1) {        l_delay = atol(argv[1]);    /* set the delay counter for busy delay */    }    if (argc > 2) {        com = argv[2];        com = com;         /* avoid compiler warning about unused parameter */    }    if (!QS_INIT(com)) {                                   /* initialize QS */        Q_ERROR();    }    printf("Dining Philosopher Problem example"           "\nQEP %s\nQF  %s\n"           "Press ESC to quit...\n",           QEP_getVersion(),           QF_getVersion());}/*..........................................................................*/void BSP_displyPhilStat(uint8_t n, char const *stat) {    printf("Philosopher %2d is %s\n", (int)n, stat);    QS_BEGIN(PHILO_STAT, AO_Philo[n])  /* application-specific record begin */        QS_U8(1, n);                                  /* Philosopher number */        QS_STR(stat);                                 /* Philosopher status */    QS_END()}/*..........................................................................*/void BSP_busyDelay(void) {    uint32_t volatile i = l_delay;    while (i-- > 0UL) {                                   /* busy-wait loop */    }}/*..........................................................................*/void Q_onAssert(char const Q_ROM * const Q_ROM_VAR file, int line) {    QF_INT_LOCK(dummy);                           /* cut-off all interrupts */    fprintf(stderr, "Assertion failed in %s, line %d", file, line);    QF_stop();}/*--------------------------------------------------------------------------*/#ifdef Q_SPY                                         /* define QS callbacks *//*..........................................................................*/static uint8_t UART_config(char const *comName, uint32_t baud) {    switch (comName[3]) {          /* Set the base address of the COMx port */        case '1': l_uart_base = (uint16_t)0x03F8; break;            /* COM1 */        case '2': l_uart_base = (uint16_t)0x02F8; break;            /* COM2 */        case '3': l_uart_base = (uint16_t)0x03E8; break;            /* COM3 */        case '4': l_uart_base = (uint16_t)0x02E8; break;            /* COM4 */        default: return (uint8_t)0;        /* COM port out of range failure */    }    baud = (uint16_t)(115200UL / baud);            /* divisor for baud rate */    outportb(l_uart_base + 3, (1 << 7));   /* Set divisor access bit (DLAB) */    outportb(l_uart_base + 0, (uint8_t)baud);               /* Load divisor */    outportb(l_uart_base + 1, (uint8_t)(baud >> 8));    outportb(l_uart_base + 3, (1 << 1) | (1 << 0));/* LCR:8-bits,no p,1stop */    outportb(l_uart_base + 4, (1 << 3) | (1 << 1) | (1 << 0));/*DTR,RTS,Out2*/    outportb(l_uart_base + 1, 0);    /* Put UART into the polling FIFO mode */    outportb(l_uart_base + 2, (1 << 2) | (1 << 0));/* FCR: enable, TX clear */    return (uint8_t)1;                                           /* success */}/*..........................................................................*/uint8_t QS_onStartup(void const *arg) {    static uint8_t qsBuf[1*1024];                 /* buffer for Quantum Spy */    QS_initBuf(qsBuf, sizeof(qsBuf));    return UART_config((char const *)arg, 115200UL);}/*..........................................................................*/void QS_onCleanup(void) {}/*..........................................................................*/QSTimeCtr QS_onGetTime(void) {            /* invoked with interrupts locked */    static uint32_t l_lastTime;    uint32_t now;    uint16_t count16;                         /* 16-bit count from the 8254 */    outportb(0x43, 0);                  /* latch the 8254's counter-0 count */    count16 = (uint16_t)inportb(0x40);    /* read the low byte of counter-0 */    count16 += ((uint16_t)inportb(0x40) << 8);        /* add on the hi byte */    now = l_tickTime + (0x10000 - count16);    if (l_lastTime > now) {                 /* are we going "back" in time? */        now += 0x10000;               /* assume that there was one rollover */    }    l_lastTime = now;    return (QSTimeCtr)now;}/*..........................................................................*/void QS_onFlush(void) {    uint16_t fifo = UART_16550_TXFIFO_DEPTH;         /* 16550 Tx FIFO depth */    uint8_t const *block;    QF_INT_LOCK(dummy);    while ((block = QS_getBlock(&fifo)) != (uint8_t *)0) {        QF_INT_UNLOCK(dummy);                                           /* busy-wait until TX FIFO empty */        while ((inportb(l_uart_base + 5) & (1 << 5)) == 0) {        }        while (fifo-- != 0) {                    /* any bytes in the block? */            outportb(l_uart_base + 0, *block++);        }        fifo = UART_16550_TXFIFO_DEPTH;      /* re-load 16550 Tx FIFO depth */        QF_INT_LOCK(dummy);    }    QF_INT_UNLOCK(dummy);}#endif                                                             /* Q_SPY *//*--------------------------------------------------------------------------*/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -