Kamil Dudka 2354d2
diff --git a/setfacl/setfacl.c b/setfacl/setfacl.c
Kamil Dudka 2354d2
index 091b9cc..be34e69 100644
Kamil Dudka 2354d2
--- a/setfacl/setfacl.c
Kamil Dudka 2354d2
+++ b/setfacl/setfacl.c
Kamil Dudka 2354d2
@@ -76,7 +76,7 @@ struct option long_options[] = {
Kamil Dudka 2354d2
 const char *progname;
Kamil Dudka 2354d2
 const char *cmd_line_options, *cmd_line_spec;
Kamil Dudka 2354d2
 
Kamil Dudka 2354d2
-int walk_flags = WALK_TREE_DEREFERENCE;
Kamil Dudka 2354d2
+int walk_flags = WALK_TREE_DEREFERENCE_TOPLEVEL;
Kamil Dudka 2354d2
 int opt_recalculate;  /* recalculate mask entry (0=default, 1=yes, -1=no) */
Kamil Dudka 2354d2
 int opt_promote;  /* promote access ACL to default ACL */
Kamil Dudka 2354d2
 int opt_test;  /* do not write to the file system.
Kamil Dudka 2354d2
@@ -580,13 +580,14 @@ int main(int argc, char *argv[])
Kamil Dudka 2354d2
 				break;
Kamil Dudka 2354d2
 
Kamil Dudka 2354d2
 			case 'L':  /* follow symlinks */
Kamil Dudka 2354d2
-				walk_flags |= WALK_TREE_LOGICAL;
Kamil Dudka 2354d2
+				walk_flags |= WALK_TREE_LOGICAL | WALK_TREE_DEREFERENCE;
Kamil Dudka 2354d2
 				walk_flags &= ~WALK_TREE_PHYSICAL;
Kamil Dudka 2354d2
 				break;
Kamil Dudka 2354d2
 
Kamil Dudka 2354d2
 			case 'P':  /* do not follow symlinks */
Kamil Dudka 2354d2
 				walk_flags |= WALK_TREE_PHYSICAL;
Kamil Dudka 2354d2
-				walk_flags &= ~WALK_TREE_LOGICAL;
Kamil Dudka 2354d2
+				walk_flags &= ~(WALK_TREE_LOGICAL | WALK_TREE_DEREFERENCE |
Kamil Dudka 2354d2
+						WALK_TREE_DEREFERENCE_TOPLEVEL);
Kamil Dudka 2354d2
 				break;
Kamil Dudka 2354d2
 
Kamil Dudka 2354d2
 			case 't':  /* test mode */