file.c (91de76e661a266731fc2889a398ad1694df9d523) | file.c (80c094a47dd4ea63375e3f60b5e076064f16e857) |
---|---|
1/* 2 * AppArmor security module 3 * 4 * This file contains AppArmor mediation of files 5 * 6 * Copyright (C) 1998-2008 Novell/SUSE 7 * Copyright 2009-2010 Canonical Ltd. 8 * --- 7 unchanged lines hidden (view full) --- 16#include <linux/fdtable.h> 17#include <linux/file.h> 18 19#include "include/apparmor.h" 20#include "include/audit.h" 21#include "include/context.h" 22#include "include/file.h" 23#include "include/match.h" | 1/* 2 * AppArmor security module 3 * 4 * This file contains AppArmor mediation of files 5 * 6 * Copyright (C) 1998-2008 Novell/SUSE 7 * Copyright 2009-2010 Canonical Ltd. 8 * --- 7 unchanged lines hidden (view full) --- 16#include <linux/fdtable.h> 17#include <linux/file.h> 18 19#include "include/apparmor.h" 20#include "include/audit.h" 21#include "include/context.h" 22#include "include/file.h" 23#include "include/match.h" |
24#include "include/net.h" | |
25#include "include/path.h" 26#include "include/policy.h" 27#include "include/label.h" 28 29static u32 map_mask_to_chr_mask(u32 mask) 30{ 31 u32 m = mask & PERMS_CHRS_MASK; 32 --- 529 unchanged lines hidden (view full) --- 562 if (!error) 563 update_file_ctx(file_ctx(file), label, request); 564 565 put_buffers(buffer); 566 567 return error; 568} 569 | 24#include "include/path.h" 25#include "include/policy.h" 26#include "include/label.h" 27 28static u32 map_mask_to_chr_mask(u32 mask) 29{ 30 u32 m = mask & PERMS_CHRS_MASK; 31 --- 529 unchanged lines hidden (view full) --- 561 if (!error) 562 update_file_ctx(file_ctx(file), label, request); 563 564 put_buffers(buffer); 565 566 return error; 567} 568 |
570static int __file_sock_perm(const char *op, struct aa_label *label, 571 struct aa_label *flabel, struct file *file, 572 u32 request, u32 denied) 573{ 574 struct socket *sock = (struct socket *) file->private_data; 575 int error; 576 577 AA_BUG(!sock); 578 579 /* revalidation due to label out of date. No revocation at this time */ 580 if (!denied && aa_label_is_subset(flabel, label)) 581 return 0; 582 583 /* TODO: improve to skip profiles cached in flabel */ 584 error = aa_sock_file_perm(label, op, request, sock); 585 if (denied) { 586 /* TODO: improve to skip profiles checked above */ 587 /* check every profile in file label to is cached */ 588 last_error(error, aa_sock_file_perm(flabel, op, request, sock)); 589 } 590 if (!error) 591 update_file_ctx(file_ctx(file), label, request); 592 593 return error; 594} 595 | |
596/** 597 * aa_file_perm - do permission revalidation check & audit for @file 598 * @op: operation being checked 599 * @label: label being enforced (NOT NULL) 600 * @file: file to revalidate access permissions on (NOT NULL) 601 * @request: requested permissions 602 * 603 * Returns: %0 if access allowed else error --- 28 unchanged lines hidden (view full) --- 632 goto done; 633 634 /* TODO: label cross check */ 635 636 if (file->f_path.mnt && path_mediated_fs(file->f_path.dentry)) 637 error = __file_path_perm(op, label, flabel, file, request, 638 denied); 639 | 569/** 570 * aa_file_perm - do permission revalidation check & audit for @file 571 * @op: operation being checked 572 * @label: label being enforced (NOT NULL) 573 * @file: file to revalidate access permissions on (NOT NULL) 574 * @request: requested permissions 575 * 576 * Returns: %0 if access allowed else error --- 28 unchanged lines hidden (view full) --- 605 goto done; 606 607 /* TODO: label cross check */ 608 609 if (file->f_path.mnt && path_mediated_fs(file->f_path.dentry)) 610 error = __file_path_perm(op, label, flabel, file, request, 611 denied); 612 |
640 else if (S_ISSOCK(file_inode(file)->i_mode)) 641 error = __file_sock_perm(op, label, flabel, file, request, 642 denied); | |
643done: 644 rcu_read_unlock(); 645 646 return error; 647} 648 649static void revalidate_tty(struct aa_label *label) 650{ --- 62 unchanged lines hidden --- | 613done: 614 rcu_read_unlock(); 615 616 return error; 617} 618 619static void revalidate_tty(struct aa_label *label) 620{ --- 62 unchanged lines hidden --- |