Tim Kientzle wrote:
The following blog post has all of my commentary on the results I have: <http://blogs.freebsdish.org/gcooper/2007/07/14/modifications-to-pkg_install-the-positive-and-negative-implications/>.


I tried to unroll strcmp a bit by checking for the first character of the
> command, then run strcmp ...

There's a somewhat more straightforward optimization that
relies on this same idea:

switch(cmd[0]) {
case 'c':
    /* Commands that start with 'c' */
    if (strcmp(cmd, 'cwd') == 0)
    return (CMD_CWD);
    /* FALLTHROUGH */
case 'd':
    /* Commands that start with 'd' */

    .... etc....
    /* FALLTHROUGH */
default:
    /* Unrecognized command. */
}

This is a little cleaner and easier to read
and may even be faster than the code you
presented in your blog.  Note that the fall through
ensures that all unrecognized commands end up at
the same place.  If unrecognized commands are
very rare (they should be), then the fallthrough
is not a performance issue.

/** malloc buffer large enough to hold +CONTENTS **/

while(!feof(file_p)) {

    /** add content via fgetc **/
}

Yuck.  Try this instead:

   struct stat st;
   int fd;
   char *buff;

   fd = open(file);
   fstat(fd, &st);
   buff = malloc(st.st_size + 1);
   read(fd, buff, st.st_size);
   buff[st.st_size] = '\0';
   close(fd);

Plus some error checking, of course.  You can
use stdio if you prefer:

   FILE *f;

   f = fopen(file, "r");
   fstat(fileno(f), &st);
   buff = malloc(st.st_size + 1);
   fread(buff, 1, st.st_size, f);
   buff[st.st_size] = '\0';
   fclose(f);

Either way, this is a lot more efficient than
tens of thousands of calls to fgetc().

Cheers,

Tim Kientzle
Tim,
   That was a very good call. I didn't even think of read(2) over fgetc(2).
That decreased the overall time by 0.7 seconds in installing vim, which is just a little shy of a 10% speedup.
-Garrett
_______________________________________________
freebsd-ports@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-ports
To unsubscribe, send any mail to "[EMAIL PROTECTED]"

Reply via email to