00001 /* 00002 * Copyright (c) 2000, 2001, 2002, 2003, 2004, 2005, 2008, 2009 00003 * The President and Fellows of Harvard College. 00004 * 00005 * Redistribution and use in source and binary forms, with or without 00006 * modification, are permitted provided that the following conditions 00007 * are met: 00008 * 1. Redistributions of source code must retain the above copyright 00009 * notice, this list of conditions and the following disclaimer. 00010 * 2. Redistributions in binary form must reproduce the above copyright 00011 * notice, this list of conditions and the following disclaimer in the 00012 * documentation and/or other materials provided with the distribution. 00013 * 3. Neither the name of the University nor the names of its contributors 00014 * may be used to endorse or promote products derived from this software 00015 * without specific prior written permission. 00016 * 00017 * THIS SOFTWARE IS PROVIDED BY THE UNIVERSITY AND CONTRIBUTORS ``AS IS'' AND 00018 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00019 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00020 * ARE DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY OR CONTRIBUTORS BE LIABLE 00021 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 00022 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 00023 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 00024 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 00025 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 00026 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 00027 * SUCH DAMAGE. 00028 */ 00029 00030 /* 00031 * Performance test from former 161 prof. Brad Chen 00032 * Stresses VM. 00033 * 00034 * Intended for the VM assignment. This should run successfully on a 00035 * variety of strides when the VM system is complete. Strides that are 00036 * not a multiple of 2 work better; see below. 00037 */ 00038 00039 #include <stdio.h> 00040 #include <stdlib.h> 00041 00042 /* 00043 * SIZE is the amount of memory used. 00044 * DEFAULT is the default stride. 00045 * Note that SIZE and DEFAULT should be relatively prime. 00046 */ 00047 #define SIZE (1024*1024/sizeof(struct entry)) 00048 #define DEFAULT 477 00049 00050 struct entry { 00051 struct entry *e; 00052 }; 00053 00054 struct entry array[SIZE]; 00055 00056 int 00057 main(int argc, char **argv) 00058 { 00059 volatile struct entry *e; 00060 unsigned i, stride; 00061 00062 stride = DEFAULT; 00063 if (argc == 2) { 00064 stride = atoi(argv[1]); 00065 } 00066 if (stride <= 0 || argc > 2) { 00067 printf("Usage: ctest [stridesize]\n"); 00068 printf(" stridesize should not be a multiple of 2.\n"); 00069 return 1; 00070 } 00071 00072 printf("Starting ctest: stride %d\n", stride); 00073 00074 /* 00075 * Generate a huge linked list, with each entry pointing to 00076 * the slot STRIDE entries above it. As long as STRIDE and SIZE 00077 * are relatively prime, this will put all the entries on one 00078 * list. Otherwise you will get multiple disjoint lists. (All 00079 * these lists will be circular.) 00080 */ 00081 for (i=0; i<SIZE; i++) { 00082 array[i].e = &array[(i+stride) % SIZE]; 00083 } 00084 00085 /* 00086 * Traverse the list. We stop after hitting each element once. 00087 * 00088 * (If STRIDE was even, this will hit some elements more than 00089 * once and others not at all.) 00090 */ 00091 e = &array[0]; 00092 for (i=0; i<SIZE; i++) { 00093 if (i % stride == 0) { 00094 putchar('.'); 00095 } 00096 e = e->e; 00097 } 00098 00099 printf("\nDone!\n"); 00100 return 0; 00101 }