|
|
1.1 ! root 1: \ ***************************************************************************** ! 2: \ * Copyright (c) 2004, 2008 IBM Corporation ! 3: \ * All rights reserved. ! 4: \ * This program and the accompanying materials ! 5: \ * are made available under the terms of the BSD License ! 6: \ * which accompanies this distribution, and is available at ! 7: \ * http://www.opensource.org/licenses/bsd-license.php ! 8: \ * ! 9: \ * Contributors: ! 10: \ * IBM Corporation - initial implementation ! 11: \ ****************************************************************************/ ! 12: ! 13: ! 14: \ Use the HPET to calculate various frequencies. ! 15: ! 16: \ Make HPET run. ! 17: 1 10 hpet! ! 18: ! 19: \ Set PMC1 to count CPU cycles. ! 20: f00 mmcr0! ! 21: ! 22: d# 1000000000000000 4 hpet@ / CONSTANT hpet-freq ! 23: ! 24: : get-times tbl@ pmc1@ f0 hpet@ ; ! 25: ! 26: \ Calculate the CPU and TB frequencies. ! 27: : calibrate get-times dup >r swap >r swap >r hpet-freq d# 100 / + >r ! 28: BEGIN get-times dup r@ < WHILE 3drop REPEAT r> drop ! 29: rot r> - ffffffff and \ TB ! 30: rot r> - ffffffff and \ CPU ! 31: rot r> - >r \ HPET ! 32: hpet-freq * r@ / swap ! 33: hpet-freq * r> / ; ! 34: ! 35: : round-to tuck 2/ + over / * ; ! 36: calibrate TO tb-frequency d# 100000000 round-to TO cpu-frequency ! 37: ! 38: \ Stop HPET. ! 39: 0 10 hpet!
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.