1 1.12 cegger /* $NetBSD: clock.c,v 1.12 2009/03/18 10:22:26 cegger Exp $ */ 2 1.1 sakamoto 3 1.1 sakamoto /* 4 1.1 sakamoto * Copyright (C) 1995, 1996 Wolfgang Solfrank. 5 1.1 sakamoto * Copyright (C) 1995, 1996 TooLs GmbH. 6 1.1 sakamoto * All rights reserved. 7 1.1 sakamoto * 8 1.1 sakamoto * Redistribution and use in source and binary forms, with or without 9 1.1 sakamoto * modification, are permitted provided that the following conditions 10 1.1 sakamoto * are met: 11 1.1 sakamoto * 1. Redistributions of source code must retain the above copyright 12 1.1 sakamoto * notice, this list of conditions and the following disclaimer. 13 1.1 sakamoto * 2. Redistributions in binary form must reproduce the above copyright 14 1.1 sakamoto * notice, this list of conditions and the following disclaimer in the 15 1.1 sakamoto * documentation and/or other materials provided with the distribution. 16 1.1 sakamoto * 3. All advertising materials mentioning features or use of this software 17 1.1 sakamoto * must display the following acknowledgement: 18 1.1 sakamoto * This product includes software developed by TooLs GmbH. 19 1.1 sakamoto * 4. The name of TooLs GmbH may not be used to endorse or promote products 20 1.1 sakamoto * derived from this software without specific prior written permission. 21 1.1 sakamoto * 22 1.1 sakamoto * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR 23 1.1 sakamoto * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 24 1.1 sakamoto * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 25 1.1 sakamoto * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 26 1.1 sakamoto * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 27 1.1 sakamoto * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 28 1.1 sakamoto * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 29 1.1 sakamoto * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 30 1.1 sakamoto * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 31 1.1 sakamoto * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 32 1.1 sakamoto */ 33 1.1 sakamoto 34 1.8 junyoung #include <lib/libsa/stand.h> 35 1.2 sakamoto #include <sys/param.h> 36 1.2 sakamoto #include <dev/isa/isareg.h> 37 1.2 sakamoto #include <dev/ic/i8253reg.h> 38 1.5 sakamoto #include "boot.h" 39 1.1 sakamoto 40 1.11 kiyohara static inline u_quad_t mftb(void); 41 1.11 kiyohara 42 1.1 sakamoto static inline u_quad_t 43 1.12 cegger mftb(void) 44 1.1 sakamoto { 45 1.1 sakamoto u_long scratch; 46 1.1 sakamoto u_quad_t tb; 47 1.6 sakamoto 48 1.10 perry __asm ("1: mftbu %0; mftb %0+1; mftbu %1; cmpw %0,%1; bne 1b" 49 1.1 sakamoto : "=r"(tb), "=r"(scratch)); 50 1.6 sakamoto return (tb); 51 1.1 sakamoto } 52 1.1 sakamoto 53 1.1 sakamoto /* 54 1.1 sakamoto * Wait for about n microseconds (at least!). 55 1.1 sakamoto */ 56 1.1 sakamoto void 57 1.11 kiyohara delay(u_int n) 58 1.1 sakamoto { 59 1.1 sakamoto u_quad_t tb; 60 1.1 sakamoto u_long tbh, tbl, scratch; 61 1.5 sakamoto 62 1.1 sakamoto tb = mftb(); 63 1.5 sakamoto tb += (n * 1000 + NS_PER_TICK - 1) / NS_PER_TICK; 64 1.1 sakamoto tbh = tb >> 32; 65 1.1 sakamoto tbl = tb; 66 1.10 perry __asm ("1: mftbu %0; cmpw %0,%1; blt 1b; bgt 2f;" 67 1.7 kleink "mftb %0; cmpw 0, %0,%2; blt 1b; 2:" 68 1.7 kleink : "=&r"(scratch) : "r"(tbh), "r"(tbl)); 69 1.1 sakamoto } 70