OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [hal/] [arm/] [xscale/] [iq80310/] [v2_0/] [src/] [diag/] [io_utils.c] - Rev 327

Go to most recent revision | Compare with Previous | Blame | View Log

//=============================================================================
//
//      io_utils.c - Cyclone Diagnostics
//
//=============================================================================
//####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):   Scott Coulter, Jeff Frazier, Eric Breeden
// Contributors:
// Date:        2001-01-25
// Purpose:     
// Description: 
//
//####DESCRIPTIONEND####
//
//===========================================================================*/
 
/*
 * i/o routines for tests.  Greg Ames, 9/17/90.
 *
 * Version: @(#)test_io.c	1.2 8/26/93
 */
#include <redboot.h>
#include <cyg/infra/diag.h>
#define printf diag_printf
 
 
#define TRUE	1
#define FALSE	0
 
 
#define ASCII_TO_DEC 48
void atod(char a, int* b)
{
    *b = (int)(a - ASCII_TO_DEC);
}
 
char xgetchar(void)
{
    hal_virtual_comm_table_t* __chan = CYGACC_CALL_IF_CONSOLE_PROCS();
 
    if (__chan == NULL)
        __chan = CYGACC_CALL_IF_DEBUG_PROCS();
 
    return CYGACC_COMM_IF_GETC(*__chan);
}
 
int xgetchar_timeout(char *ch, int msec)
{
    bool res;
    int old_to;
    hal_virtual_comm_table_t *__chan;
 
    __chan = CYGACC_CALL_IF_CONSOLE_PROCS();
    if (__chan == NULL)
	__chan = CYGACC_CALL_IF_DEBUG_PROCS();
 
    old_to = CYGACC_COMM_IF_CONTROL(*__chan, __COMMCTL_SET_TIMEOUT, msec);
    res = CYGACC_COMM_IF_GETC_TIMEOUT(*__chan, ch);
    CYGACC_COMM_IF_CONTROL(*__chan, __COMMCTL_SET_TIMEOUT, old_to);
 
    return res;
}
 
/*
 * naive implementation of "gets"
 * (big difference from fgets == strips newline character)
 */
char* sgets(char *s)
{
    char *retval = s;
    char ch;
 
    while ((ch = (char)xgetchar())) {
	if (ch == 0x0d) { /* user typed enter */
	    printf("\n");
	    break;
	}
	if (ch == 0x08) { /* user typed backspace */
	    printf ("\b");
	    printf (" ");
	    printf ("\b");
	    s--;
	} else { /* user typed another character */
	    printf("%c", ch);
	    *s++ = ch;   
	}
    }
 
    *s = '\0';
    return retval; 
}
 
 
/* Returns true if theChar is a valid hex digit, false if not */
char ishex(char theChar)
{
    switch(theChar) {
    case '0':
    case '1':
    case '2':
    case '3':
    case '4':
    case '5':
    case '6':
    case '7':
    case '8':
    case '9':
    case 'A':
    case 'a':
    case 'B':
    case 'b':
    case 'C':
    case 'c':
    case 'D':
    case 'd':
    case 'E':
    case 'e':
    case 'F':
    case 'f':
	return 1;
    default:
	return 0;
    }
}
 
 
/* Returns true if theChar is a valid decimal digit, false if not */
char isdec(char theChar)
{
    switch(theChar) {
    case '0':
    case '1':
    case '2':
    case '3':
    case '4':
    case '5':
    case '6':
    case '7':
    case '8':
    case '9':
	return 1;
    default:
	return 0;
    }
}
 
/* Convert ascii code of hex digit to number (0-15) */
char hex2dec(char hex)
{
    if ((hex >= '0') && (hex <= '9'))
        return hex - '0';
    else if ((hex >= 'a') && (hex <= 'f'))
        return hex - 'a' + 10;
    else
        return hex - 'A' + 10;
}
 
 
/* Convert number (0-15) to ascii code of hex digit */
char dec2hex(char dec)
{
    return (dec <= 9) ? (dec + '0') : (dec - 10 + 'A');
}
 
 
/* Output an 8 bit number as 2 hex digits */
void hex8out(unsigned char num)
{
    printf("%02X",num);
}
 
 
/* Output an 32 bit number as 8 hex digits */
void hex32out(unsigned long num)
{
    printf("%08X",num);
}
 
 
/* Input a number as (at most 8) hex digits - returns value entered */
long hexIn(void)
{
    char input[40];
    long num;
    register int i;
 
    i = 0;
    num = 0;
 
    if (sgets (input)) { /* grab a line */
        num = hex2dec(input[i++]);            /* Convert MSD to dec */
        while(ishex(input[i]) && input[i]) {  /* Get next hex digit */
            num <<= 4;						/* Make room for next digit */
            num += hex2dec(input[i++]); 	/* Add it in */
        }
    }
    return num;
}
 
 
/* Input a number as decimal digits - returns value entered */
long decIn(void)
{
    char input[40];
    int num;
    int tmp;
    register int i;
 
    i = 0;
    num = 0;
 
    if (sgets (input)) {  /* grab a line */
        atod(input[i++], &num);      	/* Convert MSD to decimal */
        while(isdec(input[i]) && input[i]) { /* Get next decimal digit */
            num *= 10;                 	/* Make room for next digit */
	    atod(input[i++], &tmp);
            num += tmp; 			/* Add it in */
        }
    }
 
    return (num);
}
 
 
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.