$NetBSD: patch-aa,v 1.3 2007/12/18 20:45:49 rumble Exp $
--- radeontool.c.orig	2007-12-17 21:35:53.000000000 -0500
+++ radeontool.c	2007-12-18 15:38:46.000000000 -0500
@@ -21,7 +21,17 @@
 #include <sys/stat.h>
 #include <fcntl.h>
 #include <sys/mman.h>
+#ifdef __NetBSD__
+#include <sys/param.h>
+#if __NetBSD_Prereq__(4,99,32)
+#include <sys/mutex.h>
+#else
+#include <sys/lock.h>
+#endif
+#include <machine/vmparam.h>
+#else /* ! __NetBSD__ */
 #include <asm/page.h>
+#endif
 
 #include "radeon_reg.h"
 
@@ -107,7 +117,7 @@
         mem_fd, 
         base
     );
-    if ((long)device_mem < 0) {
+    if (device_mem == MAP_FAILED) {
         if(debug)
             fprintf(stderr,"mmap returned %d\n",(int)device_mem);
         fatal("mmap error \n");
@@ -251,7 +261,6 @@
     } else if(forkrc == 0) { /* if child */
         close(pipefd[0]);
         dup2(pipefd[1],1);  /* stdout */
-        setenv("PATH","/sbin:/usr/sbin:/bin:/usr/bin",1);
         execlp("lspci","lspci","-v",NULL);
         fatal("exec lspci failure\n");
     }
@@ -307,7 +316,13 @@
        }
        if(debug) 
           printf("%s",line);
-       if(strstr(line,"emory") && strstr(line,"K")) {  /* if line contains a "Memory" and "K" string */
+       if(strstr(line,"emory") &&
+#ifdef __NetBSD__
+       strstr(line,"non-prefetch"))
+#else
+       strstr(line,"K"))
+#endif
+       {  /* if line contains a "Memory" and "K" string */
           break;
        }
     };
