security.c 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. * JFFS2 -- Journalling Flash File System, Version 2.
  3. *
  4. * Copyright © 2006 NEC Corporation
  5. *
  6. * Created by KaiGai Kohei <kaigai@ak.jp.nec.com>
  7. *
  8. * For licensing information, see the file 'LICENCE' in this directory.
  9. *
  10. */
  11. #include <linux/kernel.h>
  12. #include <linux/slab.h>
  13. #include <linux/fs.h>
  14. #include <linux/time.h>
  15. #include <linux/pagemap.h>
  16. #include <linux/highmem.h>
  17. #include <linux/crc32.h>
  18. #include <linux/jffs2.h>
  19. #include <linux/xattr.h>
  20. #include <linux/mtd/mtd.h>
  21. #include <linux/security.h>
  22. #include "nodelist.h"
  23. /* ---- Initial Security Label Attachment -------------- */
  24. int jffs2_init_security(struct inode *inode, struct inode *dir)
  25. {
  26. int rc;
  27. size_t len;
  28. void *value;
  29. char *name;
  30. rc = security_inode_init_security(inode, dir, &name, &value, &len);
  31. if (rc) {
  32. if (rc == -EOPNOTSUPP)
  33. return 0;
  34. return rc;
  35. }
  36. rc = do_jffs2_setxattr(inode, JFFS2_XPREFIX_SECURITY, name, value, len, 0);
  37. kfree(name);
  38. kfree(value);
  39. return rc;
  40. }
  41. /* ---- XATTR Handler for "security.*" ----------------- */
  42. static int jffs2_security_getxattr(struct inode *inode, const char *name,
  43. void *buffer, size_t size)
  44. {
  45. if (!strcmp(name, ""))
  46. return -EINVAL;
  47. return do_jffs2_getxattr(inode, JFFS2_XPREFIX_SECURITY, name, buffer, size);
  48. }
  49. static int jffs2_security_setxattr(struct inode *inode, const char *name, const void *buffer,
  50. size_t size, int flags)
  51. {
  52. if (!strcmp(name, ""))
  53. return -EINVAL;
  54. return do_jffs2_setxattr(inode, JFFS2_XPREFIX_SECURITY, name, buffer, size, flags);
  55. }
  56. static size_t jffs2_security_listxattr(struct inode *inode, char *list, size_t list_size,
  57. const char *name, size_t name_len)
  58. {
  59. size_t retlen = XATTR_SECURITY_PREFIX_LEN + name_len + 1;
  60. if (list && retlen <= list_size) {
  61. strcpy(list, XATTR_SECURITY_PREFIX);
  62. strcpy(list + XATTR_SECURITY_PREFIX_LEN, name);
  63. }
  64. return retlen;
  65. }
  66. struct xattr_handler jffs2_security_xattr_handler = {
  67. .prefix = XATTR_SECURITY_PREFIX,
  68. .list = jffs2_security_listxattr,
  69. .set = jffs2_security_setxattr,
  70. .get = jffs2_security_getxattr
  71. };