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

📄 hal_diag.c

📁 开放源码实时操作系统源码.
💻 C
📖 第 1 页 / 共 2 页
字号:
//=============================================================================
//
//      hal_diag.c
//
//      HAL diagnostic output code
//
//=============================================================================
//####ECOSGPLCOPYRIGHTBEGIN####
// -------------------------------------------
// This file is part of eCos, the Embedded Configurable Operating System.
// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
//
// eCos is free software; you can redistribute it and/or modify it under
// the terms of the GNU General Public License as published by the Free
// Software Foundation; either version 2 or (at your option) any later version.
//
// eCos is distributed in the hope that it will be useful, but WITHOUT ANY
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
// for more details.
//
// You should have received a copy of the GNU General Public License along
// with eCos; if not, write to the Free Software Foundation, Inc.,
// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
//
// As a special exception, if other files instantiate templates or use macros
// or inline functions from this file, or you compile this file and link it
// with other works to produce a work based on this file, this file does not
// by itself cause the resulting work to be covered by the GNU General Public
// License. However the source code for this file must still be made available
// in accordance with section (3) of the GNU General Public License.
//
// This exception does not invalidate any other reasons why a work based on
// this file might be covered by the GNU General Public License.
//
// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
// at http://sources.redhat.com/ecos/ecos-license/
// -------------------------------------------
//####ECOSGPLCOPYRIGHTEND####
//=============================================================================
//#####DESCRIPTIONBEGIN####
//
// Author(s):    Bob Koninckx
// Contributors: Bob Koninckx
// Date:         2001-12-11
// Purpose:      HAL diagnostic output
// Description:  Implementations of HAL diagnostic output support.
//
//####DESCRIPTIONEND####
//
//=============================================================================

#include <pkgconf/hal.h>

#include <cyg/hal/hal_diag.h>           // our header.

#include <cyg/infra/cyg_type.h>         // base types, externC
#include <cyg/hal/drv_api.h>            // CYG_ISR_HANDLED
#include <cyg/hal/hal_misc.h>           // Helper functions
#include <cyg/hal/hal_io.h>             // IO macros
#include <cyg/hal/hal_intr.h>           // Interrupt macros

#include <cyg/hal/hal_arch.h>           // SAVE/RESTORE GP
#include <cyg/hal/hal_if.h>             // Calling-if API


static void cyg_hal_plf_serial_init(void);

void
cyg_hal_plf_comms_init(void)
{
    static int initialized = 0;

    if (initialized)
        return;

    initialized = 1;

    cyg_hal_plf_serial_init();
}

//=============================================================================
// Serial driver
//=============================================================================

//-----------------------------------------------------------------------------
// There are two serial ports.
#define CYG_DEV_SERIAL_BASE_A    0x305008 // SCI0
#define CYG_DEV_SERIAL_BASE_B    0x305020 // SCI1

//-----------------------------------------------------------------------------
// Define CYG_DEVICE_SERIAL_RS232_SCIBR
// Default baudrate is 38400
// These values are calculated for a 40Mhz clock frequency
// This should be enough, we did not provide clock frequency as a configuration 
// option anyway
#define CYG_DEV_SERIAL_RS232_SCxBR_300    4167
#define CYG_DEV_SERIAL_RS232_SCxBR_600    2083
#define CYG_DEV_SERIAL_RS232_SCxBR_1200   1042
#define CYG_DEV_SERIAL_RS232_SCxBR_2400    521
#define CYG_DEV_SERIAL_RS232_SCxBR_4800    260
#define CYG_DEV_SERIAL_RS232_SCxBR_9600    130 
#define CYG_DEV_SERIAL_RS232_SCxBR_14400    87
#define CYG_DEV_SERIAL_RS232_SCxBR_19200    65
#define CYG_DEV_SERIAL_RS232_SCxBR_28800    43
#define CYG_DEV_SERIAL_RS232_SCxBR_38400    33
#define CYG_DEV_SERIAL_RS232_SCxBR_57600    22
#define CYG_DEV_SERIAL_RS232_SCxBR_115200   11

//-----------------------------------------------------------------------------
// Define the serial registers.
#define CYG_DEV_SERIAL_RS232_SCCR0 0x00
#define CYG_DEV_SERIAL_RS232_SCCR1 0x01
#define CYG_DEV_SERIAL_RS232_SCSR  0x02
#define CYG_DEV_SERIAL_RS232_SCDR  0x03

#define SCCR0_OTHR   0x8000 // Select baud rate other than system clock
#define SCCR0_LINKBD 0x4000 // Link baud
#define SCCR0_SCxBR  0x1fff // SCI baud rate

#define SCCR1_LOOPS  0x4000 // Loop mode
#define SCCR1_WOMS   0x2000 // Wired or for SCI pins
#define SCCR1_ILT    0x1000 // Idle line detect type
#define SCCR1_PT     0x0800 // Parity type (0 = Odd, 1 = Even)
#define SCCR1_PE     0x0400 // Parity enable
#define SCCR1_M      0x0200 // Mode select (0 = 10 bit frame, 1 = 11 bit frame)
#define SCCR1_WAKE   0x0100 // Wakeup by address mark
#define SCCR1_TIE    0x0080 // Transmit interrupt enable
#define SCCR1_TCIE   0x0040 // Transmit complete interrupt enable
#define SCCR1_RIE    0x0020 // Receiver interrupt enable
#define SCCR1_ILIE   0x0010 // Idle line interrupt enable
#define SCCR1_TE     0x0008 // Transmiter enable
#define SCCR1_RE     0x0004 // Receiver enable
#define SCCR1_RWU    0x0002 // Receiver wakeup
#define SCCR1_SBK    0x0001 // Send break

#define SCSR_TDRE    0x0100 // Transmit data register empty
#define SCSR_TC      0x0080 // Transmit complete
#define SCSR_RDRF    0x0040 // Receive data register full
#define SCSR_RAF     0x0020 // Receive active flag
#define SCSR_IDLE    0x0010 // Idle line detected
#define SCSR_OR      0x0008 // Overrun error
#define SCSR_NF      0x0004 // Noise error flag
#define SCSR_FE      0x0002 // Framing error
#define SCSR_PF      0x0001 // Parity error

//-----------------------------------------------------------------------------
typedef struct {
    cyg_uint16*  base;                // Base address of the register set
    cyg_int32    msec_timeout;        // How long do we wait
    int          imb3_vector;         // The vector on the IMB3. No need to worry
                                      // about SIU levels or vectors, that's the
                                      // responsibility of the application
	int          baud_rate;
} channel_data_t;

//-----------------------------------------------------------------------------
static void
init_serial_channel(const channel_data_t* __ch_data)
{
    cyg_uint16 * base = __ch_data->base;
    cyg_uint16 br;
    
    switch(__ch_data->baud_rate)
    {
    case 300:
        br = CYG_DEV_SERIAL_RS232_SCxBR_300;
	    break;
    case 600:
        br = CYG_DEV_SERIAL_RS232_SCxBR_600;
        break;
    case 1200:
        br = CYG_DEV_SERIAL_RS232_SCxBR_1200;
        break;
    case 2400:
        br = CYG_DEV_SERIAL_RS232_SCxBR_2400;
        break;
    case 4800:
        br = CYG_DEV_SERIAL_RS232_SCxBR_4800;
        break;
    case 9600:
        br = CYG_DEV_SERIAL_RS232_SCxBR_9600;
        break;
    case 14400:
        br = CYG_DEV_SERIAL_RS232_SCxBR_14400;
        break;
    case 19200:
        br = CYG_DEV_SERIAL_RS232_SCxBR_19200;
        break;
    case 28800:
        br = CYG_DEV_SERIAL_RS232_SCxBR_28800;
        break;
    case 38400:
        br = CYG_DEV_SERIAL_RS232_SCxBR_38400;
        break;
    case 57600:
        br = CYG_DEV_SERIAL_RS232_SCxBR_57600;
        break;
    case 115200:
        br = CYG_DEV_SERIAL_RS232_SCxBR_115200;
        break;
    default:
        // Use the default if something unknown is requested
        br = CYG_DEV_SERIAL_RS232_SCxBR_38400;
        break;
    }
    
    // 8-1-No parity, enable transmitter and receiver, leave interrupts
	// as they are
    HAL_WRITE_UINT16(base+CYG_DEV_SERIAL_RS232_SCCR1, (SCCR1_TE | SCCR1_RE));
       
    // Set baud rate
    HAL_WRITE_UINT16(base+CYG_DEV_SERIAL_RS232_SCCR0, br);
}

static cyg_bool
cyg_hal_plf_serial_getc_nonblock(void* __ch_data, cyg_uint8* ch)
{
    cyg_uint16 status;
    cyg_uint16 result;
    cyg_uint16 * base = ((channel_data_t *)__ch_data)->base;

    HAL_READ_UINT16(base+CYG_DEV_SERIAL_RS232_SCSR, status);
    if((status & SCSR_RDRF) == 0)
        return false;

    HAL_READ_UINT16(base+CYG_DEV_SERIAL_RS232_SCDR, result);
    *ch = (cyg_uint8)(result & 0x00ff);

    return true;
}


cyg_uint8
cyg_hal_plf_serial_getc(void* __ch_data)
{
    cyg_uint8 ch;
    CYGARC_HAL_SAVE_GP();

    while(!cyg_hal_plf_serial_getc_nonblock(__ch_data, &ch));

    CYGARC_HAL_RESTORE_GP();
    return ch;
}

void
cyg_hal_plf_serial_putc(void* __ch_data, cyg_uint8 c)
{
    cyg_uint16 status;
    cyg_uint16 * base = ((channel_data_t *)__ch_data)->base;

    CYGARC_HAL_SAVE_GP();
    
    do {
       HAL_READ_UINT16(base+CYG_DEV_SERIAL_RS232_SCSR, status);
    } while((status & SCSR_TDRE) == 0);

    HAL_WRITE_UINT16(base+CYG_DEV_SERIAL_RS232_SCDR, (short)c);

    // Hang around until the character is safely sent
    do {
       HAL_READ_UINT16(base+CYG_DEV_SERIAL_RS232_SCSR, status);
    } while((status & SCSR_TDRE) == 0);
         
    CYGARC_HAL_RESTORE_GP();
}

// Channel data
// Do NOT make them const, will cause problems when trying
// to change the timeout parameter ... (Is this a bug in other)
// PowerPC platform hals ?? You only see it when you really start from
// flash ....
static channel_data_t channels[2] = {
    { (cyg_uint16*)CYG_DEV_SERIAL_BASE_A, 
      1000,
      CYGNUM_HAL_INTERRUPT_IMB3_SCI0_RX,
      CYGNUM_HAL_VIRTUAL_VECTOR_CONSOLE_CHANNEL_BAUD },
    { (cyg_uint16*)CYG_DEV_SERIAL_BASE_B, 
      1000, 
      CYGNUM_HAL_INTERRUPT_IMB3_SCI1_RX,
      CYGNUM_HAL_VIRTUAL_VECTOR_CONSOLE_CHANNEL_BAUD }
};

static void
cyg_hal_plf_serial_write(void* __ch_data, const cyg_uint8* __buf, 
                         cyg_uint32 __len)
{
    CYGARC_HAL_SAVE_GP();

    while(__len-- > 0)
        cyg_hal_plf_serial_putc(__ch_data, *__buf++);

    CYGARC_HAL_RESTORE_GP();
}

static void
cyg_hal_plf_serial_read(void* __ch_data, cyg_uint8* __buf, cyg_uint32 __len)
{
    CYGARC_HAL_SAVE_GP();

    while(__len-- > 0)
        *__buf++ = cyg_hal_plf_serial_getc(__ch_data);

    CYGARC_HAL_RESTORE_GP();
}

cyg_bool
cyg_hal_plf_serial_getc_timeout(void* __ch_data, cyg_uint8* ch)
{

⌨️ 快捷键说明

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