From f0fa9d8e26a168f99db691b7c3109e0d150bdc0b Mon Sep 17 00:00:00 2001 From: scottl Date: Mon, 5 May 2003 03:21:44 +0000 Subject: Fix wmmon to work with the new devstat interface in 5-current. --- sysutils/wmmon/files/patch-ae | 177 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 177 insertions(+) create mode 100644 sysutils/wmmon/files/patch-ae diff --git a/sysutils/wmmon/files/patch-ae b/sysutils/wmmon/files/patch-ae new file mode 100644 index 000000000000..5ba2ce6e413b --- /dev/null +++ b/sysutils/wmmon/files/patch-ae @@ -0,0 +1,177 @@ +*** wmmon.c.orig Sun May 4 21:15:27 2003 +--- wmmon.c Sun May 4 21:16:48 2003 +*************** +*** 93,99 **** +--- 93,104 ---- + #include + #include + #include ++ #if __FreeBSD_version < 500101 + #include ++ #endif ++ #if __FreeBSD_version >= 500106 ++ #include ++ #endif + #if __FreeBSD_version >= 300000 + #include + #endif +*************** +*** 190,196 **** + + void wmmon_routine(int, char **); + +! void main(int argc, char *argv[]) { + + int i; + +--- 195,201 ---- + + void wmmon_routine(int, char **); + +! int main(int argc, char *argv[]) { + + int i; + +*************** +*** 230,236 **** +--- 235,245 ---- + } + } + ++ #if __FreeBSD_version >= 500106 ++ if( devstat_checkversion(NULL) < 0 ) ++ #else + if( checkversion() < 0 ) ++ #endif + { + fprintf( stderr, devstat_errbuf ); + exit(1); +*************** +*** 338,345 **** + if( nlp->n_type == 0 ) + fprintf (stderr, "kvm_nlist: Symbol '%s' not found\n", nlp->n_name); + } +! +! #if __FreeBSD_version >= 300000 + ndrives = getnumdevs(); + #else + if (nl[0].n_type != 0) { +--- 347,356 ---- + if( nlp->n_type == 0 ) + fprintf (stderr, "kvm_nlist: Symbol '%s' not found\n", nlp->n_name); + } +! +! #if __FreeBSD_version >= 500106 +! ndrives = devstat_getnumdevs(NULL); +! #elif __FreeBSD_version >= 300000 + ndrives = getnumdevs(); + #else + if (nl[0].n_type != 0) { +*************** +*** 936,942 **** +--- 947,957 ---- + static int initted = 0; + static struct statinfo last; + static struct statinfo cur; ++ #if __FreeBSD_version >= 500106 ++ int ndevs = devstat_getnumdevs(NULL); ++ #else + int ndevs = getnumdevs(); ++ #endif + int gotdevs = 0; + long generation; + int num_devices_specified = 0; +*************** +*** 986,995 **** +--- 1001,1018 ---- + memcpy( &last, &cur, sizeof(cur) ); + cur.dinfo = tmp; + ++ #if __FreeBSD_version >= 500106 ++ last.snap_time = cur.snap_time; ++ #else + last.busy_time = cur.busy_time; ++ #endif + } + ++ #if __FreeBSD_version >= 500106 ++ if( !gotdevs && ( devstat_getdevs( NULL, &cur ) >= 0 ) ) ++ #else + if( !gotdevs && ( getdevs( &cur ) >= 0 ) ) ++ #endif + gotdevs = 1; + + if( gotdevs ) +*************** +*** 999,1005 **** +--- 1022,1032 ---- + + if( !initted ) + { ++ #if __FreeBSD_version >= 500106 ++ devstat_selectdevs( &dev_select, &num_selected, &num_selections, ++ #else + selectdevs( &dev_select, &num_selected, &num_selections, ++ #endif + &select_generation, generation, cur.dinfo->devices, + ndevs, matches, num_matches, specified_devices, + num_devices_specified, DS_SELECT_ONLY, maxshowdevs, +*************** +*** 1010,1019 **** +--- 1037,1054 ---- + struct devinfo *tmpinfo; + long tmp; + ++ #if __FreeBSD_version >= 500106 ++ switch( devstat_getdevs( NULL, &cur ) ) ++ #else + switch( getdevs( &cur ) ) ++ #endif + { + case 1: ++ #if __FreeBSD_version >= 500106 ++ devstat_selectdevs( &dev_select, &num_selected, ++ #else + selectdevs( &dev_select, &num_selected, ++ #endif + &num_selections, &select_generation, + generation, cur.dinfo->devices, + ndevs, matches, num_matches, +*************** +*** 1041,1053 **** +--- 1076,1096 ---- + memcpy( &last, &cur, sizeof(cur) ); + cur.dinfo = tmpinfo; + ++ #if __FreeBSD_version >= 500106 ++ last.snap_time = cur.snap_time; ++ #else + last.busy_time = cur.busy_time; ++ #endif + break; + default: + break; + } + ++ #if __FreeBSD_version >= 500106 ++ devstat_selectdevs( &dev_select, &num_selected, &num_selections, ++ #else + selectdevs( &dev_select, &num_selected, &num_selections, ++ #endif + &select_generation, generation, cur.dinfo->devices, + ndevs, matches, num_matches, specified_devices, + num_devices_specified, DS_SELECT_ONLY, maxshowdevs, +*************** +*** 1068,1074 **** +--- 1111,1121 ---- + long double busy_seconds; + long double blocks_per_second, ms_per_transaction; + ++ #if __FreeBSD_version >= 500106 ++ busy_seconds = cur.snap_time - last.snap_time; ++ #else + busy_seconds = compute_etime( cur.busy_time, last.busy_time ); ++ #endif + + for( dn = 0; dn < ndevs; dn++ ) + { -- cgit