diff options
| author | Dmitry Kasatkin <d.kasatkin@samsung.com> | 2014-02-27 13:16:47 -0500 |
|---|---|---|
| committer | Mimi Zohar <zohar@linux.vnet.ibm.com> | 2014-03-07 12:15:48 -0500 |
| commit | 1d91ac6213003f525ac34da5e39cbb6612d19deb (patch) | |
| tree | 8182a8b6df13e506b1888fce3395b75a9aa1f23b | |
| parent | e0420039b643a832231028000a5c0d7358b14f3b (diff) | |
ima: skip memory allocation for empty files
Memory allocation is unnecessary for empty files.
This patch calculates the hash without memory allocation.
Signed-off-by: Dmitry Kasatkin <d.kasatkin@samsung.com>
Signed-off-by: Mimi Zohar <zohar@linux.vnet.ibm.com>
| -rw-r--r-- | security/integrity/ima/ima_crypto.c | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/security/integrity/ima/ima_crypto.c b/security/integrity/ima/ima_crypto.c index d257e3631152..1bde8e627766 100644 --- a/security/integrity/ima/ima_crypto.c +++ b/security/integrity/ima/ima_crypto.c | |||
| @@ -87,16 +87,20 @@ static int ima_calc_file_hash_tfm(struct file *file, | |||
| 87 | if (rc != 0) | 87 | if (rc != 0) |
| 88 | return rc; | 88 | return rc; |
| 89 | 89 | ||
| 90 | rbuf = kzalloc(PAGE_SIZE, GFP_KERNEL); | 90 | i_size = i_size_read(file_inode(file)); |
| 91 | if (!rbuf) { | 91 | |
| 92 | rc = -ENOMEM; | 92 | if (i_size == 0) |
| 93 | goto out; | 93 | goto out; |
| 94 | } | 94 | |
| 95 | rbuf = kzalloc(PAGE_SIZE, GFP_KERNEL); | ||
| 96 | if (!rbuf) | ||
| 97 | return -ENOMEM; | ||
| 98 | |||
| 95 | if (!(file->f_mode & FMODE_READ)) { | 99 | if (!(file->f_mode & FMODE_READ)) { |
| 96 | file->f_mode |= FMODE_READ; | 100 | file->f_mode |= FMODE_READ; |
| 97 | read = 1; | 101 | read = 1; |
| 98 | } | 102 | } |
| 99 | i_size = i_size_read(file_inode(file)); | 103 | |
| 100 | while (offset < i_size) { | 104 | while (offset < i_size) { |
| 101 | int rbuf_len; | 105 | int rbuf_len; |
| 102 | 106 | ||
| @@ -113,12 +117,12 @@ static int ima_calc_file_hash_tfm(struct file *file, | |||
| 113 | if (rc) | 117 | if (rc) |
| 114 | break; | 118 | break; |
| 115 | } | 119 | } |
| 116 | kfree(rbuf); | ||
| 117 | if (!rc) | ||
| 118 | rc = crypto_shash_final(&desc.shash, hash->digest); | ||
| 119 | if (read) | 120 | if (read) |
| 120 | file->f_mode &= ~FMODE_READ; | 121 | file->f_mode &= ~FMODE_READ; |
| 122 | kfree(rbuf); | ||
| 121 | out: | 123 | out: |
| 124 | if (!rc) | ||
| 125 | rc = crypto_shash_final(&desc.shash, hash->digest); | ||
| 122 | return rc; | 126 | return rc; |
| 123 | } | 127 | } |
| 124 | 128 | ||
