aboutsummaryrefslogtreecommitdiffstats
path: root/security/integrity/evm
diff options
context:
space:
mode:
authorMimi Zohar <zohar@linux.vnet.ibm.com>2011-08-11 01:22:30 -0400
committerMimi Zohar <zohar@linux.vnet.ibm.com>2011-09-14 15:24:51 -0400
commita924ce0b35875ef9512135b46a32f4150fd700b2 (patch)
tree0e01ac679790fe96c03b341b2670a2ed9c56a122 /security/integrity/evm
parentfb88c2b6cbb1265a8bef60694699b37f5cd4ba76 (diff)
evm: limit verifying current security.evm integrity
evm_protect_xattr unnecessarily validates the current security.evm integrity, before updating non-evm protected extended attributes and other file metadata. This patch limits validating the current security.evm integrity to evm protected metadata. Signed-off-by: Mimi Zohar <zohar@us.ibm.com>
Diffstat (limited to 'security/integrity/evm')
-rw-r--r--security/integrity/evm/evm_main.c58
1 files changed, 24 insertions, 34 deletions
diff --git a/security/integrity/evm/evm_main.c b/security/integrity/evm/evm_main.c
index f0127e536f84..7d4247535f9e 100644
--- a/security/integrity/evm/evm_main.c
+++ b/security/integrity/evm/evm_main.c
@@ -159,21 +159,6 @@ enum integrity_status evm_verifyxattr(struct dentry *dentry,
159EXPORT_SYMBOL_GPL(evm_verifyxattr); 159EXPORT_SYMBOL_GPL(evm_verifyxattr);
160 160
161/* 161/*
162 * evm_protect_xattr - protect the EVM extended attribute
163 *
164 * Prevent security.evm from being modified or removed.
165 */
166static int evm_protect_xattr(struct dentry *dentry, const char *xattr_name,
167 const void *xattr_value, size_t xattr_value_len)
168{
169 if (strcmp(xattr_name, XATTR_NAME_EVM) == 0) {
170 if (!capable(CAP_SYS_ADMIN))
171 return -EPERM;
172 }
173 return 0;
174}
175
176/*
177 * evm_verify_current_integrity - verify the dentry's metadata integrity 162 * evm_verify_current_integrity - verify the dentry's metadata integrity
178 * @dentry: pointer to the affected dentry 163 * @dentry: pointer to the affected dentry
179 * 164 *
@@ -189,6 +174,26 @@ static enum integrity_status evm_verify_current_integrity(struct dentry *dentry)
189 return evm_verify_hmac(dentry, NULL, NULL, 0, NULL); 174 return evm_verify_hmac(dentry, NULL, NULL, 0, NULL);
190} 175}
191 176
177/*
178 * evm_protect_xattr - protect the EVM extended attribute
179 *
180 * Prevent security.evm from being modified or removed.
181 */
182static int evm_protect_xattr(struct dentry *dentry, const char *xattr_name,
183 const void *xattr_value, size_t xattr_value_len)
184{
185 enum integrity_status evm_status;
186
187 if (strcmp(xattr_name, XATTR_NAME_EVM) == 0) {
188 if (!capable(CAP_SYS_ADMIN))
189 return -EPERM;
190 } else if (!evm_protected_xattr(xattr_name))
191 return 0;
192
193 evm_status = evm_verify_current_integrity(dentry);
194 return evm_status == INTEGRITY_PASS ? 0 : -EPERM;
195}
196
192/** 197/**
193 * evm_inode_setxattr - protect the EVM extended attribute 198 * evm_inode_setxattr - protect the EVM extended attribute
194 * @dentry: pointer to the affected dentry 199 * @dentry: pointer to the affected dentry
@@ -202,16 +207,8 @@ static enum integrity_status evm_verify_current_integrity(struct dentry *dentry)
202int evm_inode_setxattr(struct dentry *dentry, const char *xattr_name, 207int evm_inode_setxattr(struct dentry *dentry, const char *xattr_name,
203 const void *xattr_value, size_t xattr_value_len) 208 const void *xattr_value, size_t xattr_value_len)
204{ 209{
205 210 return evm_protect_xattr(dentry, xattr_name, xattr_value,
206 enum integrity_status evm_status; 211 xattr_value_len);
207 int ret;
208
209 ret = evm_protect_xattr(dentry, xattr_name, xattr_value,
210 xattr_value_len);
211 if (ret)
212 return ret;
213 evm_status = evm_verify_current_integrity(dentry);
214 return evm_status == INTEGRITY_PASS ? 0 : -EPERM;
215} 212}
216 213
217/** 214/**
@@ -224,14 +221,7 @@ int evm_inode_setxattr(struct dentry *dentry, const char *xattr_name,
224 */ 221 */
225int evm_inode_removexattr(struct dentry *dentry, const char *xattr_name) 222int evm_inode_removexattr(struct dentry *dentry, const char *xattr_name)
226{ 223{
227 enum integrity_status evm_status; 224 return evm_protect_xattr(dentry, xattr_name, NULL, 0);
228 int ret;
229
230 ret = evm_protect_xattr(dentry, xattr_name, NULL, 0);
231 if (ret)
232 return ret;
233 evm_status = evm_verify_current_integrity(dentry);
234 return evm_status == INTEGRITY_PASS ? 0 : -EPERM;
235} 225}
236 226
237/** 227/**
@@ -286,7 +276,7 @@ int evm_inode_setattr(struct dentry *dentry, struct iattr *attr)
286 unsigned int ia_valid = attr->ia_valid; 276 unsigned int ia_valid = attr->ia_valid;
287 enum integrity_status evm_status; 277 enum integrity_status evm_status;
288 278
289 if (ia_valid & ~(ATTR_MODE | ATTR_UID | ATTR_GID)) 279 if (!(ia_valid & (ATTR_MODE | ATTR_UID | ATTR_GID)))
290 return 0; 280 return 0;
291 evm_status = evm_verify_current_integrity(dentry); 281 evm_status = evm_verify_current_integrity(dentry);
292 return evm_status == INTEGRITY_PASS ? 0 : -EPERM; 282 return evm_status == INTEGRITY_PASS ? 0 : -EPERM;