diff options
author | Paul Moore <paul.moore@hp.com> | 2007-12-21 17:58:11 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 18:00:01 -0500 |
commit | afeb14b49098ba7a51c96e083a4105a0301f94c4 (patch) | |
tree | 2675451596adbea8aa261704c356d074136abbbd /net/xfrm/xfrm_policy.c | |
parent | dfd4f0ae2e111e2b93c295938c0e64ebbb69ae6e (diff) |
[XFRM]: RFC4303 compliant auditing
This patch adds a number of new IPsec audit events to meet the auditing
requirements of RFC4303. This includes audit hooks for the following events:
* Could not find a valid SA [sections 2.1, 3.4.2]
. xfrm_audit_state_notfound()
. xfrm_audit_state_notfound_simple()
* Sequence number overflow [section 3.3.3]
. xfrm_audit_state_replay_overflow()
* Replayed packet [section 3.4.3]
. xfrm_audit_state_replay()
* Integrity check failure [sections 3.4.4.1, 3.4.4.2]
. xfrm_audit_state_icvfail()
While RFC4304 deals only with ESP most of the changes in this patch apply to
IPsec in general, i.e. both AH and ESP. The one case, integrity check
failure, where ESP specific code had to be modified the same was done to the
AH code for the sake of consistency.
Signed-off-by: Paul Moore <paul.moore@hp.com>
Acked-by: James Morris <jmorris@namei.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/xfrm/xfrm_policy.c')
-rw-r--r-- | net/xfrm/xfrm_policy.c | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/net/xfrm/xfrm_policy.c b/net/xfrm/xfrm_policy.c index abc3e39b115b..280f8ded975c 100644 --- a/net/xfrm/xfrm_policy.c +++ b/net/xfrm/xfrm_policy.c | |||
@@ -2407,12 +2407,11 @@ void xfrm_audit_policy_add(struct xfrm_policy *xp, int result, | |||
2407 | { | 2407 | { |
2408 | struct audit_buffer *audit_buf; | 2408 | struct audit_buffer *audit_buf; |
2409 | 2409 | ||
2410 | if (audit_enabled == 0) | 2410 | audit_buf = xfrm_audit_start("SPD-add"); |
2411 | return; | ||
2412 | audit_buf = xfrm_audit_start(auid, secid); | ||
2413 | if (audit_buf == NULL) | 2411 | if (audit_buf == NULL) |
2414 | return; | 2412 | return; |
2415 | audit_log_format(audit_buf, " op=SPD-add res=%u", result); | 2413 | xfrm_audit_helper_usrinfo(auid, secid, audit_buf); |
2414 | audit_log_format(audit_buf, " res=%u", result); | ||
2416 | xfrm_audit_common_policyinfo(xp, audit_buf); | 2415 | xfrm_audit_common_policyinfo(xp, audit_buf); |
2417 | audit_log_end(audit_buf); | 2416 | audit_log_end(audit_buf); |
2418 | } | 2417 | } |
@@ -2423,12 +2422,11 @@ void xfrm_audit_policy_delete(struct xfrm_policy *xp, int result, | |||
2423 | { | 2422 | { |
2424 | struct audit_buffer *audit_buf; | 2423 | struct audit_buffer *audit_buf; |
2425 | 2424 | ||
2426 | if (audit_enabled == 0) | 2425 | audit_buf = xfrm_audit_start("SPD-delete"); |
2427 | return; | ||
2428 | audit_buf = xfrm_audit_start(auid, secid); | ||
2429 | if (audit_buf == NULL) | 2426 | if (audit_buf == NULL) |
2430 | return; | 2427 | return; |
2431 | audit_log_format(audit_buf, " op=SPD-delete res=%u", result); | 2428 | xfrm_audit_helper_usrinfo(auid, secid, audit_buf); |
2429 | audit_log_format(audit_buf, " res=%u", result); | ||
2432 | xfrm_audit_common_policyinfo(xp, audit_buf); | 2430 | xfrm_audit_common_policyinfo(xp, audit_buf); |
2433 | audit_log_end(audit_buf); | 2431 | audit_log_end(audit_buf); |
2434 | } | 2432 | } |