<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  </head>
  <body text="#000000" bgcolor="#FFFFFF">
    <div class="moz-cite-prefix">Was that for the whole series, or just
      this patch? :)<br>
      <br>
      Thanks,<br>
      <br>
      -<br>
      Lionel<br>
      <br>
      On 18/07/18 21:42, Jason Ekstrand wrote:<br>
    </div>
    <blockquote type="cite"
cite="mid:CAOFGe96AyaL4T-bhzGXmKW7eSFrFBxvYgyHEFf2TTG_Fg0b7XQ@mail.gmail.com">
      <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
      <div dir="ltr">
        <div>Very sketchily</div>
        <div><br>
        </div>
        <div>Reviewed-by: Jason Ekstrand <<a
            href="mailto:jason@jlekstrand.net" moz-do-not-send="true">jason@jlekstrand.net</a>><br>
        </div>
      </div>
      <br>
      <div class="gmail_quote">
        <div dir="ltr">On Wed, Jul 18, 2018 at 10:21 AM Lionel
          Landwerlin <<a href="mailto:lionel.g.landwerlin@intel.com"
            moz-do-not-send="true">lionel.g.landwerlin@intel.com</a>>
          wrote:<br>
        </div>
        <blockquote class="gmail_quote" style="margin:0 0 0
          .8ex;border-left:1px #ccc solid;padding-left:1ex">In commit
          86cb05a6d35a52 ("intel: aubinator: remove standard input<br>
          processing option") we removed the ability to process aub as
          an input<br>
          stream because we're now rely on mmapping the aub file to back
          the<br>
          buffers aubinator is parsing.<br>
          <br>
          intel_aubdump was the provider of the standard input data and
          since<br>
          we've copied/reworked intel_aubdump into intel_dump_gpu within
          Mesa,<br>
          we don't need that code anymore.<br>
          <br>
          Signed-off-by: Lionel Landwerlin <<a
            href="mailto:lionel.g.landwerlin@intel.com" target="_blank"
            moz-do-not-send="true">lionel.g.landwerlin@intel.com</a>><br>
          ---<br>
           src/intel/tools/intel_dump_gpu.c  | 121
          +++++++-----------------------<br>
           src/intel/tools/<a href="http://intel_dump_gpu.in"
            rel="noreferrer" target="_blank" moz-do-not-send="true">intel_dump_gpu.in</a>
          |  27 +------<br>
           2 files changed, 29 insertions(+), 119 deletions(-)<br>
          <br>
          diff --git a/src/intel/tools/intel_dump_gpu.c
          b/src/intel/tools/intel_dump_gpu.c<br>
          index 6d2c4b7f983..5fd2c8ea723 100644<br>
          --- a/src/intel/tools/intel_dump_gpu.c<br>
          +++ b/src/intel/tools/intel_dump_gpu.c<br>
          @@ -53,8 +53,8 @@ static int (*libc_close)(int fd) =
          close_init_helper;<br>
           static int (*libc_ioctl)(int fd, unsigned long request, ...)
          = ioctl_init_helper;<br>
          <br>
           static int drm_fd = -1;<br>
          -static char *filename = NULL;<br>
          -static FILE *files[2] = { NULL, NULL };<br>
          +static char *output_filename = NULL;<br>
          +static FILE *output_file = NULL;<br>
           static int verbose = 0;<br>
           static bool device_override;<br>
          <br>
          @@ -111,7 +111,7 @@ align_u32(uint32_t v, uint32_t a)<br>
          <br>
           static struct gen_device_info devinfo = {0};<br>
           static uint32_t device;<br>
          -static struct aub_file aubs[2];<br>
          +static struct aub_file aub_file;<br>
          <br>
           static void *<br>
           relocate_bo(struct bo *bo, const struct
          drm_i915_gem_execbuffer2 *execbuffer2,<br>
          @@ -205,28 +205,21 @@ dump_execbuffer2(int fd, struct
          drm_i915_gem_execbuffer2 *execbuffer2)<br>
                 fail_if(!gen_get_device_info(device, &devinfo),<br>
                         "failed to identify chipset=0x%x\n", device);<br>
          <br>
          -      for (int i = 0; i < ARRAY_SIZE(files); i++) {<br>
          -         if (files[i] != NULL) {<br>
          -            aub_file_init(&aubs[i], files[i], device);<br>
          -            if (verbose == 2)<br>
          -               aubs[i].verbose_log_file = stdout;<br>
          -            aub_write_header(&aubs[i],
          program_invocation_short_name);<br>
          -         }<br>
          -      }<br>
          +      aub_file_init(&aub_file, output_file, device);<br>
          +      if (verbose == 2)<br>
          +         aub_file.verbose_log_file = stdout;<br>
          +      aub_write_header(&aub_file,
          program_invocation_short_name);<br>
          <br>
                 if (verbose)<br>
                    printf("[intel_aubdump: running, "<br>
                           "output file %s, chipset id 0x%04x, gen
          %d]\n",<br>
          -                filename, device, devinfo.gen);<br>
          +                output_filename, device, devinfo.gen);<br>
              }<br>
          <br>
          -   /* Any aub */<br>
          -   struct aub_file *any_aub = files[0] ? &aubs[0] :
          &aubs[1];;<br>
          -<br>
          -   if (aub_use_execlists(any_aub))<br>
          +   if (aub_use_execlists(&aub_file))<br>
                 offset = 0x1000;<br>
              else<br>
          -      offset = aub_gtt_size(any_aub);<br>
          +      offset = aub_gtt_size(&aub_file);<br>
          <br>
              if (verbose)<br>
                 printf("Dumping execbuffer2:\n");<br>
          @@ -263,13 +256,8 @@ dump_execbuffer2(int fd, struct
          drm_i915_gem_execbuffer2 *execbuffer2)<br>
                    bo->map = gem_mmap(fd, obj->handle, 0,
          bo->size);<br>
                 fail_if(bo->map == MAP_FAILED, "intel_aubdump: bo
          mmap failed\n");<br>
          <br>
          -      for (int i = 0; i < ARRAY_SIZE(files); i++) {<br>
          -         if (files[i] == NULL)<br>
          -            continue;<br>
          -<br>
          -         if (aub_use_execlists(&aubs[i]))<br>
          -            aub_map_ppgtt(&aubs[i], bo->offset,
          bo->size);<br>
          -      }<br>
          +      if (aub_use_execlists(&aub_file))<br>
          +         aub_map_ppgtt(&aub_file, bo->offset,
          bo->size);<br>
              }<br>
          <br>
              batch_index = (execbuffer2->flags &
          I915_EXEC_BATCH_FIRST) ? 0 :<br>
          @@ -284,30 +272,21 @@ dump_execbuffer2(int fd, struct
          drm_i915_gem_execbuffer2 *execbuffer2)<br>
                 else<br>
                    data = bo->map;<br>
          <br>
          -      for (int i = 0; i < ARRAY_SIZE(files); i++) {<br>
          -         if (files[i] == NULL)<br>
          -            continue;<br>
          -<br>
          -         if (bo == batch_bo) {<br>
          -            aub_write_trace_block(&aubs[i],
          AUB_TRACE_TYPE_BATCH,<br>
          -                                  GET_PTR(data), bo->size,
          bo->offset);<br>
          -         } else {<br>
          -            aub_write_trace_block(&aubs[i],
          AUB_TRACE_TYPE_NOTYPE,<br>
          -                                  GET_PTR(data), bo->size,
          bo->offset);<br>
          -         }<br>
          +      if (bo == batch_bo) {<br>
          +         aub_write_trace_block(&aub_file,
          AUB_TRACE_TYPE_BATCH,<br>
          +                               GET_PTR(data), bo->size,
          bo->offset);<br>
          +      } else {<br>
          +         aub_write_trace_block(&aub_file,
          AUB_TRACE_TYPE_NOTYPE,<br>
          +                               GET_PTR(data), bo->size,
          bo->offset);<br>
                 }<br>
          +<br>
                 if (data != bo->map)<br>
                    free(data);<br>
              }<br>
          <br>
          -   for (int i = 0; i < ARRAY_SIZE(files); i++) {<br>
          -      if (files[i] != NULL)<br>
          -         continue;<br>
          -<br>
          -      aub_write_exec(&aubs[i],<br>
          -                     batch_bo->offset +
          execbuffer2->batch_start_offset,<br>
          -                     offset, ring_flag);<br>
          -   }<br>
          +   aub_write_exec(&aub_file,<br>
          +                  batch_bo->offset +
          execbuffer2->batch_start_offset,<br>
          +                  offset, ring_flag);<br>
          <br>
              if (device_override &&<br>
                  (execbuffer2->flags & I915_EXEC_FENCE_ARRAY) !=
          0) {<br>
          @@ -358,40 +337,6 @@ close(int fd)<br>
              return libc_close(fd);<br>
           }<br>
          <br>
          -static FILE *<br>
          -launch_command(char *command)<br>
          -{<br>
          -   int i = 0, fds[2];<br>
          -   char **args = calloc(strlen(command), sizeof(char *));<br>
          -   char *iter = command;<br>
          -<br>
          -   args[i++] = iter = command;<br>
          -<br>
          -   while ((iter = strstr(iter, ",")) != NULL) {<br>
          -      *iter = '\0';<br>
          -      iter += 1;<br>
          -      args[i++] = iter;<br>
          -   }<br>
          -<br>
          -   if (pipe(fds) == -1)<br>
          -      return NULL;<br>
          -<br>
          -   switch (fork()) {<br>
          -   case 0:<br>
          -      dup2(fds[0], 0);<br>
          -      fail_if(execvp(args[0], args) == -1,<br>
          -              "intel_aubdump: failed to launch child
          command\n");<br>
          -      return NULL;<br>
          -<br>
          -   default:<br>
          -      free(args);<br>
          -      return fdopen(fds[1], "w");<br>
          -<br>
          -   case -1:<br>
          -      return NULL;<br>
          -   }<br>
          -}<br>
          -<br>
           static void<br>
           maybe_init(void)<br>
           {<br>
          @@ -418,16 +363,11 @@ maybe_init(void)<br>
                            value);<br>
                    device_override = true;<br>
                 } else if (!strcmp(key, "file")) {<br>
          -         filename = strdup(value);<br>
          -         files[0] = fopen(filename, "w+");<br>
          -         fail_if(files[0] == NULL,<br>
          +         output_filename = strdup(value);<br>
          +         output_file = fopen(output_filename, "w+");<br>
          +         fail_if(output_file == NULL,<br>
                            "intel_aubdump: failed to open file '%s'\n",<br>
          -                 filename);<br>
          -      } else if (!strcmp(key,  "command")) {<br>
          -         files[1] = launch_command(value);<br>
          -         fail_if(files[1] == NULL,<br>
          -                 "intel_aubdump: failed to launch command
          '%s'\n",<br>
          -                 value);<br>
          +                 output_filename);<br>
                 } else {<br>
                    fprintf(stderr, "intel_aubdump: unknown option
          '%s'\n", key);<br>
                 }<br>
          @@ -598,12 +538,7 @@ ioctl_init_helper(int fd, unsigned long
          request, ...)<br>
           static void __attribute__ ((destructor))<br>
           fini(void)<br>
           {<br>
          -   free(filename);<br>
          -   for (int i = 0; i < ARRAY_SIZE(files); i++) {<br>
          -      if (aubs[i].file)<br>
          -         aub_file_finish(&aubs[i]);<br>
          -      else if (files[i])<br>
          -         fclose(files[i]);<br>
          -   }<br>
          +   free(output_filename);<br>
          +   aub_file_finish(&aub_file);<br>
              free(bos);<br>
           }<br>
          diff --git a/src/intel/tools/<a
            href="http://intel_dump_gpu.in" rel="noreferrer"
            target="_blank" moz-do-not-send="true">intel_dump_gpu.in</a>
          b/src/intel/tools/<a href="http://intel_dump_gpu.in"
            rel="noreferrer" target="_blank" moz-do-not-send="true">intel_dump_gpu.in</a><br>
          index b9887f0ed2e..9eea37189db 100755<br>
          --- a/src/intel/tools/<a href="http://intel_dump_gpu.in"
            rel="noreferrer" target="_blank" moz-do-not-send="true">intel_dump_gpu.in</a><br>
          +++ b/src/intel/tools/<a href="http://intel_dump_gpu.in"
            rel="noreferrer" target="_blank" moz-do-not-send="true">intel_dump_gpu.in</a><br>
          @@ -10,9 +10,6 @@ contents and execution of the GEM
          application.<br>
          <br>
             -o, --output=FILE  Name of AUB file. Defaults to
          COMMAND.aub<br>
          <br>
          -  -c, --command=CMD  Execute CMD and write the AUB file's
          content to its<br>
          -                     standard input<br>
          -<br>
                 --device=ID    Override PCI ID of the reported device<br>
          <br>
             -v                 Enable verbose output<br>
          @@ -27,7 +24,6 @@ EOF<br>
           }<br>
          <br>
           args=""<br>
          -command=""<br>
           file=""<br>
          <br>
           function add_arg() {<br>
          @@ -35,17 +31,6 @@ function add_arg() {<br>
               args="$args$arg\n"<br>
           }<br>
          <br>
          -function build_command () {<br>
          -    command=""<br>
          -    for i in $1; do<br>
          -        if [ -z $command ]; then<br>
          -            command=$i<br>
          -        else<br>
          -            command="$command,$i"<br>
          -        fi;<br>
          -    done<br>
          -}<br>
          -<br>
           while true; do<br>
               case "$1" in<br>
                   -o)<br>
          @@ -71,16 +56,6 @@ while true; do<br>
                       add_arg "file=${<a class="moz-txt-link-freetext" href="file:-$(basename">file:-$(basename</a> ${file}).aub}"<br>
                       shift<br>
                       ;;<br>
          -        -c)<br>
          -            build_command "$2"<br>
          -            add_arg "command=$command"<br>
          -            shift 2<br>
          -            ;;<br>
          -        --command=*)<br>
          -            build_command "${1##--command=}"<br>
          -            add_arg "command=$command"<br>
          -            shift<br>
          -            ;;<br>
                   --device=*)<br>
                       add_arg "device=${1##--device=}"<br>
                       shift<br>
          @@ -105,7 +80,7 @@ done<br>
          <br>
           [ -z $1 ] && show_help<br>
          <br>
          -[ -z $file ] && [ -z $command ] && add_arg
          "file=intel.aub"<br>
          +[ -z $file ] && add_arg "file=intel.aub"<br>
          <br>
 LD_PRELOAD=<a class="moz-txt-link-rfc2396E" href="mailto:@install_libexecdir@/libintel_dump_gpu.so${LD_PPRELOAD:+:$LD_PRELOAD}">"@install_libexecdir@/libintel_dump_gpu.so${LD_PPRELOAD:+:$LD_PRELOAD}"</a>
          \<br>
                     exec -- "$@" 3<<EOF<br>
          -- <br>
          2.18.0<br>
          <br>
          _______________________________________________<br>
          mesa-dev mailing list<br>
          <a href="mailto:mesa-dev@lists.freedesktop.org"
            target="_blank" moz-do-not-send="true">mesa-dev@lists.freedesktop.org</a><br>
          <a
            href="https://lists.freedesktop.org/mailman/listinfo/mesa-dev"
            rel="noreferrer" target="_blank" moz-do-not-send="true">https://lists.freedesktop.org/mailman/listinfo/mesa-dev</a><br>
        </blockquote>
      </div>
    </blockquote>
    <p><br>
    </p>
  </body>
</html>