1 1.1 jruoho /* $NetBSD: t_tree.c,v 1.1 2011/05/05 13:36:05 jruoho Exp $ */ 2 1.1 jruoho 3 1.1 jruoho /*- 4 1.1 jruoho * Copyright (c) 2010, 2011 The NetBSD Foundation, Inc. 5 1.1 jruoho * All rights reserved. 6 1.1 jruoho * 7 1.1 jruoho * Redistribution and use in source and binary forms, with or without 8 1.1 jruoho * modification, are permitted provided that the following conditions 9 1.1 jruoho * are met: 10 1.1 jruoho * 1. Redistributions of source code must retain the above copyright 11 1.1 jruoho * notice, this list of conditions and the following disclaimer. 12 1.1 jruoho * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 jruoho * notice, this list of conditions and the following disclaimer in the 14 1.1 jruoho * documentation and/or other materials provided with the distribution. 15 1.1 jruoho * 16 1.1 jruoho * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 17 1.1 jruoho * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 18 1.1 jruoho * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 19 1.1 jruoho * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 20 1.1 jruoho * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 1.1 jruoho * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 1.1 jruoho * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 23 1.1 jruoho * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 24 1.1 jruoho * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 25 1.1 jruoho * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 26 1.1 jruoho * POSSIBILITY OF SUCH DAMAGE. 27 1.1 jruoho */ 28 1.1 jruoho 29 1.1 jruoho #include <sys/cdefs.h> 30 1.1 jruoho #include <sys/tree.h> 31 1.1 jruoho 32 1.1 jruoho #include <atf-c.h> 33 1.1 jruoho #include <stdlib.h> 34 1.1 jruoho #include <stdio.h> 35 1.1 jruoho 36 1.1 jruoho struct mist { 37 1.1 jruoho RB_ENTRY(mist) rbentry; 38 1.1 jruoho int key; 39 1.1 jruoho }; 40 1.1 jruoho RB_HEAD(head, mist) tt; 41 1.1 jruoho 42 1.1 jruoho static int 43 1.1 jruoho mistcmp(struct mist *a, struct mist *b) 44 1.1 jruoho { 45 1.1 jruoho #if 0 46 1.1 jruoho return (b->key - a->key); /* wrong, can overflow */ 47 1.1 jruoho #else 48 1.1 jruoho if (b->key > a->key) 49 1.1 jruoho return 1; 50 1.1 jruoho else if (b->key < a->key) 51 1.1 jruoho return (-1); 52 1.1 jruoho else 53 1.1 jruoho return 0; 54 1.1 jruoho #endif 55 1.1 jruoho } 56 1.1 jruoho 57 1.1 jruoho RB_PROTOTYPE(head, mist, rbentry, mistcmp) 58 1.1 jruoho RB_GENERATE(head, mist, rbentry, mistcmp) 59 1.1 jruoho 60 1.1 jruoho static struct mist * 61 1.1 jruoho addmist(int key) 62 1.1 jruoho { 63 1.1 jruoho struct mist *m; 64 1.1 jruoho 65 1.1 jruoho m = malloc(sizeof(struct mist)); 66 1.1 jruoho m->key = key; 67 1.1 jruoho RB_INSERT(head, &tt, m); 68 1.1 jruoho return m; 69 1.1 jruoho } 70 1.1 jruoho 71 1.1 jruoho static int 72 1.1 jruoho findmist(struct mist *m) 73 1.1 jruoho { 74 1.1 jruoho 75 1.1 jruoho return (!!RB_FIND(head, &tt, m)); 76 1.1 jruoho } 77 1.1 jruoho 78 1.1 jruoho #define N 1000 79 1.1 jruoho static int 80 1.1 jruoho test(void) 81 1.1 jruoho { 82 1.1 jruoho struct mist *m[N]; 83 1.1 jruoho int fail, i, j; 84 1.1 jruoho 85 1.1 jruoho RB_INIT(&tt); 86 1.1 jruoho fail = 0; 87 1.1 jruoho for (i = 0; i < N; i++) { 88 1.1 jruoho m[i] = addmist(random() << 1); /* use all 32 bits */ 89 1.1 jruoho for (j = 0; j <= i; j++) 90 1.1 jruoho if (!findmist(m[j])) 91 1.1 jruoho fail++; 92 1.1 jruoho } 93 1.1 jruoho return fail; 94 1.1 jruoho } 95 1.1 jruoho 96 1.1 jruoho ATF_TC(tree_rbstress); 97 1.1 jruoho ATF_TC_HEAD(tree_rbstress, tc) 98 1.1 jruoho { 99 1.1 jruoho 100 1.1 jruoho atf_tc_set_md_var(tc, "descr", "rb-tree stress test"); 101 1.1 jruoho } 102 1.1 jruoho 103 1.1 jruoho ATF_TC_BODY(tree_rbstress, tc) 104 1.1 jruoho { 105 1.1 jruoho int i, fail, f; 106 1.1 jruoho 107 1.1 jruoho srandom(4711); 108 1.1 jruoho fail = 0; 109 1.1 jruoho for (i = 0; i < 10; i++) { 110 1.1 jruoho f = test(); 111 1.1 jruoho if (f) { 112 1.1 jruoho atf_tc_fail_nonfatal("loop %d: %d errors\n", i, f); 113 1.1 jruoho fail += f; 114 1.1 jruoho } 115 1.1 jruoho } 116 1.1 jruoho } 117 1.1 jruoho 118 1.1 jruoho ATF_TP_ADD_TCS(tp) 119 1.1 jruoho { 120 1.1 jruoho 121 1.1 jruoho ATF_TP_ADD_TC(tp, tree_rbstress); 122 1.1 jruoho 123 1.1 jruoho return atf_no_error(); 124 1.1 jruoho } 125