On Thu, 23 Mar 2023 08:28:01 -0700
Srikanth Yalavarthi <syalavar...@marvell.com> wrote:

> +     if (fseek(fp, 0, SEEK_END) == 0) {
> +             file_size = ftell(fp);
> +             if (file_size == -1) {
> +                     ret = -EIO;
> +                     goto error;
> +             }
> +
> +             file_buffer = rte_malloc(NULL, file_size, RTE_CACHE_LINE_SIZE);
> +             if (file_buffer == NULL) {
> +                     ml_err("Failed to allocate memory: %s\n", file);
> +                     ret = -ENOMEM;
> +                     goto error;
> +             }
> +
> +             if (fseek(fp, 0, SEEK_SET) != 0) {
> +                     ret = -EIO;
> +                     goto error;
> +             }
> +
> +             if (fread(file_buffer, sizeof(char), file_size, fp) != 
> (unsigned long)file_size) {
> +                     ml_err("Failed to read file : %s\n", file);
> +                     ret = -EIO;
> +                     goto error;
> +             }
> +             fclose(fp);
> +     } else {
> +             ret = -EIO;
> +             goto error;
> +     }
> +
> +     *buffer = file_buffer;
> +     *size = file_size;
> +
> +     return 0;

Granted this only test code, but is the slowest way to do this.
Stdio is buffered (in 4K chunks). And using rte_malloc comes from hugepages.

Three levels of improvement are possible:
  1. don't use rte_malloc() use malloc() instead.
  2. use direct system call for I/O
  3. use mmap() to directly map in the file instead read

Reply via email to