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

Subversion Repositories w11

[/] [w11/] [tags/] [w11a_V0.61/] [tools/] [fx2/] [src/] [lib/] [delay.c] - Diff between revs 17 and 26

Only display areas with differences | Details | Blame | View Log

Rev 17 Rev 26
/* -*- c++ -*- */
/* -*- c++ -*- */
/* $Id: delay.c 395 2011-07-17 22:02:55Z mueller $ */
/* $Id: delay.c 395 2011-07-17 22:02:55Z mueller $ */
/*-----------------------------------------------------------------------------
/*-----------------------------------------------------------------------------
 * Delay routines
 * Delay routines
 *-----------------------------------------------------------------------------
 *-----------------------------------------------------------------------------
 * Code taken from USRP2 firmware (GNU Radio Project), version 3.0.2,
 * Code taken from USRP2 firmware (GNU Radio Project), version 3.0.2,
 * Copyright 2003 Free Software Foundation, Inc.
 * Copyright 2003 Free Software Foundation, Inc.
 *-----------------------------------------------------------------------------
 *-----------------------------------------------------------------------------
 * This code is part of usbjtag. usbjtag is free software; you can redistribute
 * This code is part of usbjtag. usbjtag is free software; you can redistribute
 * it and/or modify it under the terms of the GNU General Public License as
 * it and/or modify it under the terms of the GNU General Public License as
 * published by the Free Software Foundation; either version 2 of the License,
 * published by the Free Software Foundation; either version 2 of the License,
 * or (at your option) any later version. usbjtag is distributed in the hope
 * or (at your option) any later version. usbjtag is distributed in the hope
 * that it will be useful, but WITHOUT ANY WARRANTY; without even the implied
 * that it will be useful, but WITHOUT ANY WARRANTY; without even the implied
 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.  You should have received a
 * GNU General Public License for more details.  You should have received a
 * copy of the GNU General Public License along with this program in the file
 * copy of the GNU General Public License along with this program in the file
 * COPYING; if not, write to the Free Software Foundation, Inc., 51 Franklin
 * COPYING; if not, write to the Free Software Foundation, Inc., 51 Franklin
 * St, Fifth Floor, Boston, MA  02110-1301  USA
 * St, Fifth Floor, Boston, MA  02110-1301  USA
 *-----------------------------------------------------------------------------
 *-----------------------------------------------------------------------------
 */
 */
 
 
/*
/*
 * Delay approximately 1 microsecond (including overhead in udelay).
 * Delay approximately 1 microsecond (including overhead in udelay).
 */
 */
static void
static void
udelay1 (void) _naked
udelay1 (void) _naked
{
{
  _asm                          ; lcall that got us here took 4 bus cycles
  _asm                          ; lcall that got us here took 4 bus cycles
        ret                     ; 4 bus cycles
        ret                     ; 4 bus cycles
  _endasm;
  _endasm;
}
}
 
 
/*
/*
 * delay for approximately usecs microseconds
 * delay for approximately usecs microseconds
 */
 */
void
void
udelay (unsigned char usecs)
udelay (unsigned char usecs)
{
{
  do {
  do {
    udelay1 ();
    udelay1 ();
  } while (--usecs != 0);
  } while (--usecs != 0);
}
}
 
 
 
 
/*
/*
 * Delay approximately 1 millisecond.
 * Delay approximately 1 millisecond.
 * We're running at 48 MHz, so we need 48,000 clock cycles.
 * We're running at 48 MHz, so we need 48,000 clock cycles.
 *
 *
 * Note however, that each bus cycle takes 4 clock cycles (not obvious,
 * Note however, that each bus cycle takes 4 clock cycles (not obvious,
 * but explains the factor of 4 problem below).
 * but explains the factor of 4 problem below).
 */
 */
static void
static void
mdelay1 (void) _naked
mdelay1 (void) _naked
{
{
  _asm
  _asm
        mov     dptr,#(-1200 & 0xffff)
        mov     dptr,#(-1200 & 0xffff)
002$:
002$:
        inc     dptr            ; 3 bus cycles
        inc     dptr            ; 3 bus cycles
        mov     a, dpl          ; 2 bus cycles
        mov     a, dpl          ; 2 bus cycles
        orl     a, dph          ; 2 bus cycles
        orl     a, dph          ; 2 bus cycles
        jnz     002$            ; 3 bus cycles
        jnz     002$            ; 3 bus cycles
 
 
        ret
        ret
  _endasm;
  _endasm;
}
}
 
 
void
void
mdelay (unsigned int msecs)
mdelay (unsigned int msecs)
{
{
  do {
  do {
    mdelay1 ();
    mdelay1 ();
  } while (--msecs != 0);
  } while (--msecs != 0);
}
}
 
 
 
 
 
 

powered by: WebSVN 2.1.0

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