- struct obd_ioctl_data data;
- int rc;
-
- IOCINIT(data);
- if (argc == 2) {
- data.ioc_obdo1.o_id = strtoul(argv[1], NULL, 0);
- data.ioc_obdo1.o_valid = 0xffffffff;
- printf("getting attr for %Ld\n", data.ioc_obdo1.o_id);
- } else {
- printf("usage %s id\n", argv[0]);
- return 0;
- }
-
- rc = ioctl(fd, OBD_IOC_GETATTR , &data);
- if (rc) {
- printf("Error: %s\n", strerror(rc));
- } else {
- printf("attr obdo %Ld, mode %o\n", data.ioc_obdo1.o_id,
- data.ioc_obdo1.o_mode);
- }
- return 0;
+ struct obd_ioctl_data data;
+ struct timeval start, next_time;
+ int i, count, next_count;
+ int verbose;
+ int rc;
+
+ if (argc != 2 && argc != 3) {
+ fprintf(stderr, "usage: %s count [verbose]\n",cmdname(argv[0]));
+ return -1;
+ }
+
+ IOCINIT(data);
+ count = strtoul(argv[1], NULL, 0);
+
+ verbose = get_verbose(argv[2]);
+
+ data.ioc_obdo1.o_valid = 0xffffffff;
+ data.ioc_obdo1.o_id = 2;
+ gettimeofday(&start, NULL);
+ next_time.tv_sec = start.tv_sec - verbose;
+ next_time.tv_usec = start.tv_usec;
+ printf("%s: getting %d attrs (testing only): %s", cmdname(argv[0]),
+ count, ctime(&start.tv_sec));
+
+ for (i = 1, next_count = verbose; i <= count; i++) {
+ rc = ioctl(fd, OBD_IOC_GETATTR , &data);
+ if (rc < 0) {
+ fprintf(stderr, "error: %s: #%d - %s\n",
+ cmdname(argv[0]), i, strerror(rc = errno));
+ break;
+ } else if (be_verbose(verbose, &next_time, i,&next_count,count))
+ printf("%s: got attr #%d\n", cmdname(argv[0]), i);
+ }
+
+ if (!rc) {
+ struct timeval end;
+ double diff;
+
+ gettimeofday(&end, NULL);
+
+ diff = difftime(&end, &start);
+
+ --i;
+ printf("%s: %d attrs in %.4gs (%.4g attr/s): %s",
+ cmdname(argv[0]), i, diff, (double)i / diff,
+ ctime(&end.tv_sec));
+ }
+ return rc;