9pfs: handle walk of ".." in the root directory
commit56f101ecce0eafd09e2daf1c4eeb1377d6959261
authorGreg Kurz <groug@kaod.org>
Tue, 30 Aug 2016 15:02:27 +0000 (30 17:02 +0200)
committerPeter Maydell <peter.maydell@linaro.org>
Tue, 30 Aug 2016 18:23:00 +0000 (30 19:23 +0100)
tree9b7c8ceb972c7a4da49bee92fff49939376e35a1
parent805b5d98c649d26fc44d2d7755a97f18e62b438a
9pfs: handle walk of ".." in the root directory

The 9P spec at http://man.cat-v.org/plan_9/5/intro says:

All directories must support walks to the directory .. (dot-dot) meaning
parent directory, although by convention directories contain no explicit
entry for .. or . (dot).  The parent of the root directory of a server's
tree is itself.

This means that a client cannot walk further than the root directory
exported by the server. In other words, if the client wants to walk
"/.." or "/foo/../..", the server should answer like the request was
to walk "/".

This patch just does that:
- we cache the QID of the root directory at attach time
- during the walk we compare the QID of each path component with the root
  QID to detect if we're in a "/.." situation
- if so, we skip the current component and go to the next one

Signed-off-by: Greg Kurz <groug@kaod.org>
Reviewed-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
hw/9pfs/9p.c
hw/9pfs/9p.h