Uploaded image for project: 'Lustre'
  1. Lustre
  2. LU-8723

llapi_obd_statfs() tests errno in non error cases, may leak file descriptors

Details

    • Bug
    • Resolution: Fixed
    • Minor
    • Lustre 2.9.0
    • Lustre 2.9.0
    • 3
    • 9223372036854775807

    Description

      In llapi_obd_statfs() we have:

              fd = open(path, O_RDONLY);
              if (errno == EISDIR)
                      fd = open(path, O_DIRECTORY | O_RDONLY);
      

      Second, if open() succeeds then the value of errno is arbitrary and the file descriptor may be leaked if errno was previously set to EISDIR.

      Also note that open() will never set errno to EISDIR when write access is not requested.

      Attachments

        Activity

          [LU-8723] llapi_obd_statfs() tests errno in non error cases, may leak file descriptors
          mdiep Minh Diep made changes -
          Link New: This issue is related to LDEV-373 [ LDEV-373 ]
          mdiep Minh Diep made changes -
          Link Original: This issue is related to LDEV-530 [ LDEV-530 ]
          mdiep Minh Diep made changes -
          Link New: This issue is related to LDEV-530 [ LDEV-530 ]
          mdiep Minh Diep made changes -
          Link New: This issue is related to LDEV-341 [ LDEV-341 ]
          mdiep Minh Diep made changes -
          Link New: This issue is related to LDEV-368 [ LDEV-368 ]
          pjones Peter Jones made changes -
          Fix Version/s New: Lustre 2.9.0 [ 11891 ]
          Resolution New: Fixed [ 1 ]
          Status Original: Open [ 1 ] New: Resolved [ 5 ]
          jhammond John Hammond created issue -

          People

            wc-triage WC Triage
            jhammond John Hammond
            Votes:
            0 Vote for this issue
            Watchers:
            3 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: