unofficial mirror of bug-guix@gnu.org 
 help / color / mirror / code / Atom feed
* bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd
@ 2019-10-28 17:27 Ivan Vilata i Balaguer
  2019-10-29 22:16 ` Ludovic Courtès
  0 siblings, 1 reply; 10+ messages in thread
From: Ivan Vilata i Balaguer @ 2019-10-28 17:27 UTC (permalink / raw)
  To: 37967

Hi!  While using Guix commit `c9fc03a3` on Debian unstable, whenever I run
`guix environment -CN` (either as a normal user or as root) I get an error
like this:

    guix environment: error: mount: mount "/var/run/nscd" on "/tmp/guix-directory.6kBgXe//var/run/nscd": Operation not permitted

nscd is installed and working in my host machine.

This command used to work a while ago.  Actually, I pulled the Guix commit
right before `5ccec771` ("file-systems: Add /var/run/nscd to
'%network-file-mappings'.") and the command seems to work again (even if I do
not replace the running daemon).

Maybe the later commit introduced some kind of regression?

Thanks and cheers!

-- 
Ivan Vilata i Balaguer -- https://elvil.net/

^ permalink raw reply	[flat|nested] 10+ messages in thread

* bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd
  2019-10-28 17:27 bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd Ivan Vilata i Balaguer
@ 2019-10-29 22:16 ` Ludovic Courtès
  2019-10-29 22:47   ` Ivan Vilata i Balaguer
  0 siblings, 1 reply; 10+ messages in thread
From: Ludovic Courtès @ 2019-10-29 22:16 UTC (permalink / raw)
  To: Ivan Vilata i Balaguer; +Cc: 37967

Bon dia Ivan,

Ivan Vilata i Balaguer <ivan@selidor.net> skribis:

> Hi!  While using Guix commit `c9fc03a3` on Debian unstable, whenever I run
> `guix environment -CN` (either as a normal user or as root) I get an error
> like this:
>
>     guix environment: error: mount: mount "/var/run/nscd" on "/tmp/guix-directory.6kBgXe//var/run/nscd": Operation not permitted
>
> nscd is installed and working in my host machine.

What does ‘uname -rs’ return?

What about ‘ls -ld /var/run/nscd’?

> This command used to work a while ago.  Actually, I pulled the Guix commit
> right before `5ccec771` ("file-systems: Add /var/run/nscd to
> '%network-file-mappings'.") and the command seems to work again (even if I do
> not replace the running daemon).
>
> Maybe the later commit introduced some kind of regression?

It definitely has to do with this commit, but I wonder why you’d get
EPERM when bind-mounting /var/run/nscd to a different place!

Gracies,
Ludo’.

^ permalink raw reply	[flat|nested] 10+ messages in thread

* bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd
  2019-10-29 22:16 ` Ludovic Courtès
@ 2019-10-29 22:47   ` Ivan Vilata i Balaguer
  2019-11-01 14:26     ` Ludovic Courtès
  0 siblings, 1 reply; 10+ messages in thread
From: Ivan Vilata i Balaguer @ 2019-10-29 22:47 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 37967, Ivan Vilata i Balaguer

Salut Ludovic !

Ludovic Courtès (2019-10-29 23:16:49 +0100) wrote:

> Bon dia Ivan,
> 
> Ivan Vilata i Balaguer <ivan@selidor.net> skribis:
> 
> > Hi!  While using Guix commit `c9fc03a3` on Debian unstable, whenever I run
> > `guix environment -CN` (either as a normal user or as root) I get an error
> > like this:
> >
> >     guix environment: error: mount: mount "/var/run/nscd" on "/tmp/guix-directory.6kBgXe//var/run/nscd": Operation not permitted
> >
> > nscd is installed and working in my host machine.
> 
> What does ‘uname -rs’ return?

    $ uname -rs
    Linux 5.2.0-3-amd64

> What about ‘ls -ld /var/run/nscd’?

    $ ls -ld /var/run/nscd
    drwxr-xr-x 2 root root 60 Oct 29 15:58 /var/run/nscd

> > This command used to work a while ago.  Actually, I pulled the Guix commit
> > right before `5ccec771` ("file-systems: Add /var/run/nscd to
> > '%network-file-mappings'.") and the command seems to work again (even if I do
> > not replace the running daemon).
> >
> > Maybe the later commit introduced some kind of regression?
> 
> It definitely has to do with this commit, but I wonder why you’d get
> EPERM when bind-mounting /var/run/nscd to a different place!
> 
> Gracies,
> Ludo’.

Yeah, I'm also scratching my head since switching to the previous commit
immediately has it working again, so it's probably not a system config
issue. `O_o`

Cheers!

-- 
Ivan Vilata i Balaguer -- https://elvil.net/

^ permalink raw reply	[flat|nested] 10+ messages in thread

* bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd
  2019-10-29 22:47   ` Ivan Vilata i Balaguer
@ 2019-11-01 14:26     ` Ludovic Courtès
  2019-11-01 15:10       ` Ivan Vilata i Balaguer
  0 siblings, 1 reply; 10+ messages in thread
From: Ludovic Courtès @ 2019-11-01 14:26 UTC (permalink / raw)
  To: Ivan Vilata i Balaguer; +Cc: 37967

Ivan Vilata i Balaguer <ivan@selidor.net> skribis:

> Salut Ludovic !

Hola!  :-)

> Ludovic Courtès (2019-10-29 23:16:49 +0100) wrote:
>
>> Bon dia Ivan,
>> 
>> Ivan Vilata i Balaguer <ivan@selidor.net> skribis:
>> 
>> > Hi!  While using Guix commit `c9fc03a3` on Debian unstable, whenever I run
>> > `guix environment -CN` (either as a normal user or as root) I get an error
>> > like this:
>> >
>> >     guix environment: error: mount: mount "/var/run/nscd" on "/tmp/guix-directory.6kBgXe//var/run/nscd": Operation not permitted
>> >
>> > nscd is installed and working in my host machine.
>> 
>> What does ‘uname -rs’ return?
>
>     $ uname -rs
>     Linux 5.2.0-3-amd64
>
>> What about ‘ls -ld /var/run/nscd’?
>
>     $ ls -ld /var/run/nscd
>     drwxr-xr-x 2 root root 60 Oct 29 15:58 /var/run/nscd

Hmm, what does this command return:

  mkdir /tmp/tt
  unshare -mUr mount --bind /var/run/nscd /tmp/tt

?

What about a read-only bind mount like this:

  unshare -mUr mount --bind -o ro /var/run/nscd /tmp/tt

?

What if you try bind-mounting a directory owned by your user?

  mkdir /tmp/mine
  unshare -mUr mount --bind /tmp/mine /tmp/tt

?

Thanks in advance,
Ludo’.

^ permalink raw reply	[flat|nested] 10+ messages in thread

* bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd
  2019-11-01 14:26     ` Ludovic Courtès
@ 2019-11-01 15:10       ` Ivan Vilata i Balaguer
  2019-11-04  3:23         ` Ivan Vilata i Balaguer
  0 siblings, 1 reply; 10+ messages in thread
From: Ivan Vilata i Balaguer @ 2019-11-01 15:10 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 37967, Ivan Vilata i Balaguer

Ludovic Courtès (2019-11-01 15:26:27 +0100) wrote:

> Ivan Vilata i Balaguer <ivan@selidor.net> skribis:
> 
> > Ludovic Courtès (2019-10-29 23:16:49 +0100) wrote:
> >> 
> >> Ivan Vilata i Balaguer <ivan@selidor.net> skribis:
> >> 
> >> > Hi!  While using Guix commit `c9fc03a3` on Debian unstable, whenever I run
> >> > `guix environment -CN` (either as a normal user or as root) I get an error
> >> > like this:
> >> >
> >> >     guix environment: error: mount: mount "/var/run/nscd" on "/tmp/guix-directory.6kBgXe//var/run/nscd": Operation not permitted
> >> >
> >> > nscd is installed and working in my host machine.
> >> 
> >> What does ‘uname -rs’ return?
> >
> >     $ uname -rs
> >     Linux 5.2.0-3-amd64
> >
> >> What about ‘ls -ld /var/run/nscd’?
> >
> >     $ ls -ld /var/run/nscd
> >     drwxr-xr-x 2 root root 60 Oct 29 15:58 /var/run/nscd
> 
> Hmm, what does this command return:
> 
>   mkdir /tmp/tt
>   unshare -mUr mount --bind /var/run/nscd /tmp/tt
> 
> ?

    $ mkdir /tmp/tt
    $ unshare -mUr mount --bind /var/run/nscd /tmp/tt && echo ok
    ok

> What about a read-only bind mount like this:
> 
>   unshare -mUr mount --bind -o ro /var/run/nscd /tmp/tt
> 
> ?

This one looks more interesting:

    $ unshare -mUr mount --bind -o ro /var/run/nscd /tmp/tt && echo ok
    mount: /tmp/tt: filesystem was mounted, but any subsequent operation failed: Unknown error 5005.
    $ echo $?
    32

> What if you try bind-mounting a directory owned by your user?
> 
>   mkdir /tmp/mine
>   unshare -mUr mount --bind /tmp/mine /tmp/tt
> 
> ?

    $ mkdir /tmp/mine
    $ unshare -mUr mount --bind /tmp/mine /tmp/tt && echo ok
    ok

> Thanks in advance,
> Ludo’.

Thanks to you!  Saluton,

-- 
Ivan Vilata i Balaguer -- https://elvil.net/

^ permalink raw reply	[flat|nested] 10+ messages in thread

* bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd
  2019-11-01 15:10       ` Ivan Vilata i Balaguer
@ 2019-11-04  3:23         ` Ivan Vilata i Balaguer
  2019-11-04 17:07           ` Ludovic Courtès
  0 siblings, 1 reply; 10+ messages in thread
From: Ivan Vilata i Balaguer @ 2019-11-04  3:23 UTC (permalink / raw)
  To: Ivan Vilata i Balaguer; +Cc: 37967

Ivan Vilata i Balaguer (2019-11-01 11:10:02 -0400) wrote:

> Ludovic Courtès (2019-11-01 15:26:27 +0100) wrote:
> 
> > […] What about a read-only bind mount like this:
> > 
> >   unshare -mUr mount --bind -o ro /var/run/nscd /tmp/tt
> > 
> > ?
> 
> This one looks more interesting:
> 
>     $ unshare -mUr mount --bind -o ro /var/run/nscd /tmp/tt && echo ok
>     mount: /tmp/tt: filesystem was mounted, but any subsequent operation failed: Unknown error 5005.
>     $ echo $?
>     32

BTW, I ran that under strace and it looks like the read-only remount fails
after mounting `/var/run/nscd` in the new namespace has succeeded:

    $ strace -f unshare -mUr mount --bind -o ro /var/run/nscd /tmp/tt
    […]
    access("/run/mount", R_OK|W_OK)         = -1 EACCES (Permission denied)
    mount("/run/nscd", "/tmp/tt", 0x14c25b0, MS_RDONLY|MS_BIND, NULL) = 0
    mount("none", "/tmp/tt", NULL, MS_RDONLY|MS_REMOUNT|MS_BIND, NULL) = -1 EPERM (Operation not permitted)
    write(2, "mount: ", 7mount: )                  = 7
    write(2, "/tmp/tt: filesystem was mounted,"..., 89/tmp/tt: filesystem was mounted, but any subsequent operation failed: Unknown error 5005.) = 89
    write(2, "\n", 1
    […]

Cheers!

-- 
Ivan Vilata i Balaguer -- https://elvil.net/

^ permalink raw reply	[flat|nested] 10+ messages in thread

* bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd
  2019-11-04  3:23         ` Ivan Vilata i Balaguer
@ 2019-11-04 17:07           ` Ludovic Courtès
  2019-11-04 21:23             ` Ivan Vilata i Balaguer
  0 siblings, 1 reply; 10+ messages in thread
From: Ludovic Courtès @ 2019-11-04 17:07 UTC (permalink / raw)
  To: Ivan Vilata i Balaguer; +Cc: 37967

[-- Attachment #1: Type: text/plain, Size: 1700 bytes --]

Saluton!

Ivan Vilata i Balaguer <ivan@selidor.net> skribis:

> Ivan Vilata i Balaguer (2019-11-01 11:10:02 -0400) wrote:
>
>> Ludovic Courtès (2019-11-01 15:26:27 +0100) wrote:
>> 
>> > […] What about a read-only bind mount like this:
>> > 
>> >   unshare -mUr mount --bind -o ro /var/run/nscd /tmp/tt
>> > 
>> > ?
>> 
>> This one looks more interesting:
>> 
>>     $ unshare -mUr mount --bind -o ro /var/run/nscd /tmp/tt && echo ok
>>     mount: /tmp/tt: filesystem was mounted, but any subsequent operation failed: Unknown error 5005.
>>     $ echo $?
>>     32
>
> BTW, I ran that under strace and it looks like the read-only remount fails
> after mounting `/var/run/nscd` in the new namespace has succeeded:
>
>     $ strace -f unshare -mUr mount --bind -o ro /var/run/nscd /tmp/tt
>     […]
>     access("/run/mount", R_OK|W_OK)         = -1 EACCES (Permission denied)
>     mount("/run/nscd", "/tmp/tt", 0x14c25b0, MS_RDONLY|MS_BIND, NULL) = 0
>     mount("none", "/tmp/tt", NULL, MS_RDONLY|MS_REMOUNT|MS_BIND, NULL) = -1 EPERM (Operation not permitted)
>     write(2, "mount: ", 7mount: )                  = 7
>     write(2, "/tmp/tt: filesystem was mounted,"..., 89/tmp/tt: filesystem was mounted, but any subsequent operation failed: Unknown error 5005.) = 89
>     write(2, "\n", 1
>     […]

Weird, why does it remount it?

What does:

  mount | grep /run

returns?  I just tried on a Debian 10 image with Linux 4.19.0 and /run
is a tmpfs, which may be the reason why read-only bind-mounts fail (or
at least there’s a bug in that area.)

Anyway, below is a patch for you to test.  Let me know how it goes.  :-)

Thanks,
Ludo’.


[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: Type: text/x-patch, Size: 759 bytes --]

diff --git a/gnu/system/file-systems.scm b/gnu/system/file-systems.scm
index 6cf6ccc53e..6cdb2b749d 100644
--- a/gnu/system/file-systems.scm
+++ b/gnu/system/file-systems.scm
@@ -507,7 +507,8 @@ a bind mount."
                  ;; XXX: On some GNU/Linux systems, /etc/resolv.conf is a
                  ;; symlink to a file in a tmpfs which, for an unknown reason,
                  ;; cannot be bind mounted read-only within the container.
-                 (writable? (string=? file "/etc/resolv.conf"))))
+                 (writable? (or (string=? file "/etc/resolv.conf")
+                                (string=? file "/var/run/nscd")))))
               (cons "/var/run/nscd" %network-configuration-files)))
 
 (define (file-system-type-predicate type)

^ permalink raw reply related	[flat|nested] 10+ messages in thread

* bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd
  2019-11-04 17:07           ` Ludovic Courtès
@ 2019-11-04 21:23             ` Ivan Vilata i Balaguer
  2019-11-04 22:37               ` Ludovic Courtès
  0 siblings, 1 reply; 10+ messages in thread
From: Ivan Vilata i Balaguer @ 2019-11-04 21:23 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 37967, Ivan Vilata i Balaguer

Ludovic Courtès (2019-11-04 18:07:05 +0100) wrote:

> Ivan Vilata i Balaguer <ivan@selidor.net> skribis:
> 
> > BTW, I ran that under strace and it looks like the read-only remount fails
> > after mounting `/var/run/nscd` in the new namespace has succeeded:
> >
> >     $ strace -f unshare -mUr mount --bind -o ro /var/run/nscd /tmp/tt
> >     […]
> >     access("/run/mount", R_OK|W_OK)         = -1 EACCES (Permission denied)
> >     mount("/run/nscd", "/tmp/tt", 0x14c25b0, MS_RDONLY|MS_BIND, NULL) = 0
> >     mount("none", "/tmp/tt", NULL, MS_RDONLY|MS_REMOUNT|MS_BIND, NULL) = -1 EPERM (Operation not permitted)
> >     write(2, "mount: ", 7mount: )                  = 7
> >     write(2, "/tmp/tt: filesystem was mounted,"..., 89/tmp/tt: filesystem was mounted, but any subsequent operation failed: Unknown error 5005.) = 89
> >     write(2, "\n", 1
> >     […]
> 
> Weird, why does it remount it?
> 
> What does:
> 
>   mount | grep /run

    $ mount | grep /run
    tmpfs on /run type tmpfs (rw,nosuid,nodev,noexec,relatime,size=1641444k,mode=755)
    […]

> returns?  I just tried on a Debian 10 image with Linux 4.19.0 and /run
> is a tmpfs, which may be the reason why read-only bind-mounts fail (or
> at least there’s a bug in that area.)
> 
> Anyway, below is a patch for you to test.  Let me know how it goes.  :-)
> 
> Thanks,
> Ludo’.

I applied your patch on top of bf7b08c4, pulled Guix and did successfully
start `guix environment -CN`, with network support and all.

Cool! `:)`


> diff --git a/gnu/system/file-systems.scm b/gnu/system/file-systems.scm
> index 6cf6ccc53e..6cdb2b749d 100644
> --- a/gnu/system/file-systems.scm
> +++ b/gnu/system/file-systems.scm
> @@ -507,7 +507,8 @@ a bind mount."
>                   ;; XXX: On some GNU/Linux systems, /etc/resolv.conf is a
>                   ;; symlink to a file in a tmpfs which, for an unknown reason,
>                   ;; cannot be bind mounted read-only within the container.
> -                 (writable? (string=? file "/etc/resolv.conf"))))
> +                 (writable? (or (string=? file "/etc/resolv.conf")
> +                                (string=? file "/var/run/nscd")))))
>                (cons "/var/run/nscd" %network-configuration-files)))
>  
>  (define (file-system-type-predicate type)

-- 
Ivan Vilata i Balaguer -- https://elvil.net/

^ permalink raw reply	[flat|nested] 10+ messages in thread

* bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd
  2019-11-04 21:23             ` Ivan Vilata i Balaguer
@ 2019-11-04 22:37               ` Ludovic Courtès
  2019-11-08 19:07                 ` Björn Höfling
  0 siblings, 1 reply; 10+ messages in thread
From: Ludovic Courtès @ 2019-11-04 22:37 UTC (permalink / raw)
  To: Ivan Vilata i Balaguer; +Cc: 37967-done

Hi,

Ivan Vilata i Balaguer <ivan@selidor.net> skribis:

> I applied your patch on top of bf7b08c4, pulled Guix and did successfully
> start `guix environment -CN`, with network support and all.

Awesome, pushed as 625bdf09d344302ec2d5da7f35fe35ca1d128a93.

Gràcies!  :-)

Ludo’.

^ permalink raw reply	[flat|nested] 10+ messages in thread

* bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd
  2019-11-04 22:37               ` Ludovic Courtès
@ 2019-11-08 19:07                 ` Björn Höfling
  0 siblings, 0 replies; 10+ messages in thread
From: Björn Höfling @ 2019-11-08 19:07 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: Ivan Vilata i Balaguer, 37967-done

[-- Attachment #1: Type: text/plain, Size: 512 bytes --]

On Mon, 04 Nov 2019 23:37:07 +0100
Ludovic Courtès <ludo@gnu.org> wrote:

> Hi,
> 
> Ivan Vilata i Balaguer <ivan@selidor.net> skribis:
> 
> > I applied your patch on top of bf7b08c4, pulled Guix and did
> > successfully start `guix environment -CN`, with network support and
> > all.  
> 
> Awesome, pushed as 625bdf09d344302ec2d5da7f35fe35ca1d128a93.

Hi,

I had the same issue and was too lazy to report. I can confirm that the
commit fixed it.

Thanks for reporting and fixing.

Björn

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 195 bytes --]

^ permalink raw reply	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2019-11-08 19:08 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-10-28 17:27 bug#37967: guix environment -CN: Operation not permitted mounting host's /var/run/nscd Ivan Vilata i Balaguer
2019-10-29 22:16 ` Ludovic Courtès
2019-10-29 22:47   ` Ivan Vilata i Balaguer
2019-11-01 14:26     ` Ludovic Courtès
2019-11-01 15:10       ` Ivan Vilata i Balaguer
2019-11-04  3:23         ` Ivan Vilata i Balaguer
2019-11-04 17:07           ` Ludovic Courtès
2019-11-04 21:23             ` Ivan Vilata i Balaguer
2019-11-04 22:37               ` Ludovic Courtès
2019-11-08 19:07                 ` Björn Höfling

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/guix.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).