bug-hurd
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH] Hurd: Fix initialization order


From: Samuel Thibault
Subject: Re: [PATCH] Hurd: Fix initialization order
Date: Mon, 14 Mar 2022 00:55:57 +0100
User-agent: NeoMutt/20170609 (1.8.3)

This looks good and seems to be working fine on my box, so I pushed it
upstream and uploaded a newer libpciaccess package (to be available
within 6h)

Thanks!!

Samuel

Joan Lledó, le sam. 12 mars 2022 19:28:04 +0100, a ecrit:
> From: Joan Lledó <jlledom@member.fsf.org>
> 
> ---
>  src/hurd_pci.c | 22 ++++++++++++----------
>  1 file changed, 12 insertions(+), 10 deletions(-)
> 
> diff --git a/src/hurd_pci.c b/src/hurd_pci.c
> index 70a9f89..653faa5 100644
> --- a/src/hurd_pci.c
> +++ b/src/hurd_pci.c
> @@ -610,7 +610,8 @@ pci_system_hurd_create(void)
>  {
>      int err;
>      struct pci_system_hurd *pci_sys_hurd;
> -    mach_port_t device_master, pci_port;
> +    mach_port_t device_master;
> +    mach_port_t pci_port = MACH_PORT_NULL;
>      mach_port_t root = MACH_PORT_NULL;
>  
>      if (&netfs_server_name && netfs_server_name
> @@ -637,23 +638,24 @@ pci_system_hurd_create(void)
>  
>      pci_sys->num_devices = 0;
>  
> -    if ((err = get_privileged_ports (NULL, &device_master)) || 
> (device_master == MACH_PORT_NULL)) {
> -        pci_system_cleanup();
> -        return err;
> +    err = get_privileged_ports (NULL, &device_master);
> +
> +    if(!err && device_master != MACH_PORT_NULL) {
> +        err = device_open (device_master, D_READ, "pci", &pci_port);
> +     mach_port_deallocate (mach_task_self (), device_master);
>      }
>  
> -    err = device_open (device_master, D_READ|D_WRITE, "pci", &pci_port);
> -    if (!err) {
> -        root = file_name_lookup_under (pci_port, ".", O_DIRECTORY | O_RDWR | 
> O_EXEC, 0);
> +    if (!err && pci_port != MACH_PORT_NULL) {
> +        root = file_name_lookup_under (pci_port, ".", O_DIRECTORY | O_RDONLY 
> | O_EXEC, 0);
>          device_close (pci_port);
>          mach_port_deallocate (mach_task_self (), pci_port);
>      }
>  
> -    if (!root) {
> -        root = file_name_lookup (_SERVERS_BUS_PCI, O_RDWR, 0);
> +    if (root == MACH_PORT_NULL) {
> +        root = file_name_lookup (_SERVERS_BUS_PCI, O_RDONLY, 0);
>      }
>  
> -    if (!root) {
> +    if (root == MACH_PORT_NULL) {
>          pci_system_cleanup();
>          return errno;
>      }
> -- 
> 2.31.1
> 
> 

-- 
Samuel
How do I type "for i in *.dvi do xdvi i done" in a GUI?
(Discussion in comp.os.linux.misc on the intuitiveness of interfaces.)



reply via email to

[Prev in Thread] Current Thread [Next in Thread]