mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-18 15:30:21 +00:00
The behavior of SPDUPDATE has been changed.
SPDUPDATE doesn't depend on whether there is a SP or not. This change makes `generate_policy on' of racoon work. Obtained from: KAME MFC after: 1 week
This commit is contained in:
parent
28070a0efe
commit
56a87de33f
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=85054
@ -1724,20 +1724,16 @@ key_spdadd(so, m, mhp)
|
||||
|
||||
/*
|
||||
* checking there is SP already or not.
|
||||
* If type is SPDUPDATE and no SP found, then error.
|
||||
* If type is either SPDADD or SPDSETIDX and SP found, then error.
|
||||
* SPDUPDATE doesn't depend on whether there is a SP or not.
|
||||
* If the type is either SPDADD or SPDSETIDX AND a SP is found,
|
||||
* then error.
|
||||
*/
|
||||
newsp = key_getsp(&spidx);
|
||||
if (mhp->msg->sadb_msg_type == SADB_X_SPDUPDATE) {
|
||||
if (newsp == NULL) {
|
||||
#ifdef IPSEC_DEBUG
|
||||
printf("key_spdadd: no SP found.\n");
|
||||
#endif
|
||||
return key_senderror(so, m, ENOENT);
|
||||
if (newsp) {
|
||||
newsp->state = IPSEC_SPSTATE_DEAD;
|
||||
key_freesp(newsp);
|
||||
}
|
||||
|
||||
newsp->state = IPSEC_SPSTATE_DEAD;
|
||||
key_freesp(newsp);
|
||||
} else {
|
||||
if (newsp != NULL) {
|
||||
key_freesp(newsp);
|
||||
|
Loading…
Reference in New Issue
Block a user