[roll] Roll fuchsia [superproject] Roll third_party/Vulkan-Loader [Vulkan-Loader] Ensure directories have read permissions

As part of the io2 migration, we must ensure all directories are
explicitly *Opened* instead of using common *Connect* operations, since
the latter does not use any flags/rights. Because of this, when a
directory is connected to like a service, the connection lacks any
rights.

The Vulkan loader callbacks that open directories and connect to
services do not take any flag arguments, so we need to infer what the
target is based on the path. As all of these paths have well known
formats, so we make two assumptions:

  1. Paths such as `/loader-gpu-devices/class/gpu/001` should be
     connected to as a service (i.e. to the underlying device
     protocol).
  2. The `/loader-gpu-devices` directory should be opened as a
     directory.
  3. All other class paths that don't point to a particular device
     instance, such `/loader-gpu-devices/class/gpu`, should be opened as
     directories.

Opening directories with PERM_READABLE will be required to enumerate
child entries of these paths.

This only works right now as in io1, many operations - like directory
enumeration - were unprivileged. In order to start enforcing the new io2
rights model, we need to require that callers opening directories (or
other node types) explicitly set the flags/rights they want.

Original-Bug: 376575307
Original-Reviewed-on: https://fuchsia-review.googlesource.com/c/third_party/Vulkan-Loader/+/1211784
Original-Revision: 804d061b2e17c0a98c35b0e3aa64d4997d2d42b7
GitOrigin-RevId: d21e91b30b38b51d3a76f25b12771db9a7e4c2b1
Original-Reviewed-on: https://fuchsia-review.googlesource.com/c/fuchsia/+/1221696
Original-Revision: ee768717912e2bc5d4f2947074dad5fdaf1c92e6
Change-Id: Ib22e27fe3071d5ef121cbad66938eef903da1a0c
1 file changed
tree: 26881566ca087fa5910ecd0a2aac7da7847a7203
  1. ctf/
  2. git-hooks/
  3. infra/
  4. third_party/
  5. cts
  6. firmware
  7. flower
  8. jiri.lock
  9. MILESTONE
  10. minimal
  11. prebuilts
  12. README.md
  13. stem
  14. test_durations
  15. toolchain
README.md

Integration

This repository contains Fuchsia's Global Integration manifest files.

Making changes

All changes should be made to the internal version of this repository. Our infrastructure automatically updates this version when the internal one changes.

Currently all changes must be made by a Google employee. Non-Google employees wishing to make a change can ask for assistance in one of the communication channels documented at get involved.

Obtaining the source

First install Jiri.

Next run:

$ jiri init
$ jiri import minimal https://fuchsia.googlesource.com/integration
$ jiri update

Third party

Third party projects should have their own subdirectory in ./third_party.