summaryrefslogtreecommitdiff
path: root/sbin/photurisd/kernel.c
diff options
context:
space:
mode:
Diffstat (limited to 'sbin/photurisd/kernel.c')
-rw-r--r--sbin/photurisd/kernel.c24
1 files changed, 22 insertions, 2 deletions
diff --git a/sbin/photurisd/kernel.c b/sbin/photurisd/kernel.c
index c8fbd122697..4cd37fd5b81 100644
--- a/sbin/photurisd/kernel.c
+++ b/sbin/photurisd/kernel.c
@@ -39,7 +39,7 @@
*/
#ifndef lint
-static char rcsid[] = "$Id: kernel.c,v 1.17 2000/12/15 01:58:27 provos Exp $";
+static char rcsid[] = "$Id: kernel.c,v 1.18 2000/12/15 02:42:08 provos Exp $";
#endif
#include <time.h>
@@ -1359,7 +1359,7 @@ kernel_request_sa(struct sadb_msg *sadb)
st = state_find(dstbuf);
tm = time(NULL);
- while (st != NULL && (st->lifetime <= tm || st->phase >= SPI_UPDATE))
+ while (st != NULL && (st->lifetime <= tm || st->phase < SPI_UPDATE))
st = state_find_next(st, dstbuf);
if (st == NULL) {
@@ -1393,10 +1393,30 @@ kernel_request_sa(struct sadb_msg *sadb)
} else
state_insert(st);
} else {
+ struct sockaddr_in sin;
+
/*
* We need different attributes for this exchange, send
* an SPI_NEEDED message.
*/
+
+ packet_size = PACKET_BUFFER_SIZE;
+ if (photuris_spi_needed(st, packet_buffer, &packet_size,
+ st->uSPIattrib,
+ st->uSPIattribsize) == -1) {
+ log_print(__FUNCTION__": photuris_spi_update()");
+ return (-1);
+ }
+
+ /* Send the packet */
+ sin.sin_port = htons(st->port);
+ sin.sin_family = AF_INET;
+ sin.sin_addr.s_addr = inet_addr(st->address);
+
+ if (sendto(global_socket, packet_buffer, packet_size, 0,
+ (struct sockaddr *)&sin, sizeof(sin)) != packet_size) {
+ log_error(__FUNCTION__": sendto()");
+ }
}
return (0);