Commit f3b9aa3d authored by David Ward's avatar David Ward Committed by Stephen Hemminger

ip/xfrm: Command syntax should not expect a key for compression

Compression algorithms do not use a key.
Signed-off-by: default avatarDavid Ward <david.ward@ll.mit.edu>
parent 8dbe67d2
...@@ -78,13 +78,14 @@ static void usage(void) ...@@ -78,13 +78,14 @@ static void usage(void)
fprintf(stderr, "ALGO-LIST := [ ALGO-LIST ] ALGO\n"); fprintf(stderr, "ALGO-LIST := [ ALGO-LIST ] ALGO\n");
fprintf(stderr, "ALGO := { "); fprintf(stderr, "ALGO := { ");
fprintf(stderr, "%s | ", strxf_algotype(XFRMA_ALG_CRYPT)); fprintf(stderr, "%s | ", strxf_algotype(XFRMA_ALG_CRYPT));
fprintf(stderr, "%s | ", strxf_algotype(XFRMA_ALG_AUTH)); fprintf(stderr, "%s", strxf_algotype(XFRMA_ALG_AUTH));
fprintf(stderr, "%s", strxf_algotype(XFRMA_ALG_COMP));
fprintf(stderr, " } ALGO-NAME ALGO-KEY |\n"); fprintf(stderr, " } ALGO-NAME ALGO-KEY |\n");
fprintf(stderr, " %s", strxf_algotype(XFRMA_ALG_AUTH_TRUNC));
fprintf(stderr, " ALGO-NAME ALGO-KEY ALGO-TRUNC-LEN |\n");
fprintf(stderr, " %s", strxf_algotype(XFRMA_ALG_AEAD)); fprintf(stderr, " %s", strxf_algotype(XFRMA_ALG_AEAD));
fprintf(stderr, " ALGO-NAME ALGO-KEY ALGO-ICV-LEN |\n"); fprintf(stderr, " ALGO-NAME ALGO-KEY ALGO-ICV-LEN |\n");
fprintf(stderr, " %s", strxf_algotype(XFRMA_ALG_AUTH_TRUNC)); fprintf(stderr, " %s", strxf_algotype(XFRMA_ALG_COMP));
fprintf(stderr, " ALGO-NAME ALGO-KEY ALGO-TRUNC-LEN\n"); fprintf(stderr, " ALGO-NAME\n");
fprintf(stderr, "MODE := transport | tunnel | ro | in_trigger | beet\n"); fprintf(stderr, "MODE := transport | tunnel | ro | in_trigger | beet\n");
fprintf(stderr, "FLAG-LIST := [ FLAG-LIST ] FLAG\n"); fprintf(stderr, "FLAG-LIST := [ FLAG-LIST ] FLAG\n");
fprintf(stderr, "FLAG := noecn | decap-dscp | nopmtudisc | wildrecv | icmp | af-unspec | align4\n"); fprintf(stderr, "FLAG := noecn | decap-dscp | nopmtudisc | wildrecv | icmp | af-unspec | align4\n");
...@@ -374,7 +375,7 @@ static int xfrm_state_modify(int cmd, unsigned flags, int argc, char **argv) ...@@ -374,7 +375,7 @@ static int xfrm_state_modify(int cmd, unsigned flags, int argc, char **argv)
int len; int len;
__u32 icvlen, trunclen; __u32 icvlen, trunclen;
char *name; char *name;
char *key; char *key = "";
char *buf; char *buf;
switch (type) { switch (type) {
...@@ -409,10 +410,17 @@ static int xfrm_state_modify(int cmd, unsigned flags, int argc, char **argv) ...@@ -409,10 +410,17 @@ static int xfrm_state_modify(int cmd, unsigned flags, int argc, char **argv)
NEXT_ARG(); NEXT_ARG();
name = *argv; name = *argv;
if (!NEXT_ARG_OK()) switch (type) {
missarg("ALGO-KEY"); case XFRMA_ALG_AEAD:
NEXT_ARG(); case XFRMA_ALG_CRYPT:
key = *argv; case XFRMA_ALG_AUTH:
case XFRMA_ALG_AUTH_TRUNC:
if (!NEXT_ARG_OK())
missarg("ALGO-KEY");
NEXT_ARG();
key = *argv;
break;
}
buf = alg.u.alg.alg_key; buf = alg.u.alg.alg_key;
len = sizeof(alg.u.alg); len = sizeof(alg.u.alg);
......
...@@ -117,14 +117,17 @@ ip-xfrm \- transform configuration ...@@ -117,14 +117,17 @@ ip-xfrm \- transform configuration
.ti -8 .ti -8
.IR ALGO " :=" .IR ALGO " :="
.RB "{ " enc " | " auth " | " comp " } " .RB "{ " enc " | " auth " } "
.IR ALGO-NAME " " ALGO-KEY " |" .IR ALGO-NAME " " ALGO-KEY " |"
.br .br
.B aead
.IR ALGO-NAME " " ALGO-KEY " " ALGO-ICV-LEN " |"
.br
.B auth-trunc .B auth-trunc
.IR ALGO-NAME " " ALGO-KEY " " ALGO-TRUNC-LEN .IR ALGO-NAME " " ALGO-KEY " " ALGO-TRUNC-LEN " |"
.br
.B aead
.IR ALGO-NAME " " ALGO-KEY " " ALGO-ICV-LEN " |"
.br
.B comp
.IR ALGO-NAME
.ti -8 .ti -8
.IR MODE " := " .IR MODE " := "
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment