diff options
author | Maria Matejka <mq@ucw.cz> | 2023-01-18 12:33:06 +0100 |
---|---|---|
committer | Maria Matejka <mq@ucw.cz> | 2023-01-18 12:33:06 +0100 |
commit | 6bb992cb04926895be57dc97e7d569ea15a07db1 (patch) | |
tree | 12f90320f7aac28711d308c76db1e51f4d4aa58b /sysdep/bsd/krt-sock.Y | |
parent | 973aa37e1e28a9c508fe09c008196f64cd3966fd (diff) | |
parent | 7144c9ca46f092da33a4e051bbce8f973a3bd8c4 (diff) |
Merge branch 'master' of https://gitlab.nic.cz/labs/bird
Diffstat (limited to 'sysdep/bsd/krt-sock.Y')
-rw-r--r-- | sysdep/bsd/krt-sock.Y | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/sysdep/bsd/krt-sock.Y b/sysdep/bsd/krt-sock.Y index 8581bd43..a03d6df5 100644 --- a/sysdep/bsd/krt-sock.Y +++ b/sysdep/bsd/krt-sock.Y @@ -10,7 +10,7 @@ CF_HDR CF_DECLS -CF_KEYWORDS(KERNEL, TABLE) +CF_KEYWORDS(KERNEL, TABLE, METRIC) CF_GRAMMAR @@ -25,6 +25,14 @@ kern_sys_item: THIS_KRT->sys.table_id = $3; } + | METRIC expr { + if ($2 && !krt_max_metric) + cf_error("Kernel route metric not supported"); + if ($2 > krt_max_metric) + cf_error("Kernel table id must be in range 0-%u", krt_max_metric); + + THIS_KRT->sys.metric = $2; + } ; CF_CODE |