diff options
author | Thomas Graf <tgraf@suug.ch> | 2006-08-07 20:58:53 -0400 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2006-09-22 17:54:02 -0400 |
commit | 6b3f8674bccbb2e784d01e44373fb730af6cb149 (patch) | |
tree | f6632cf6c5a06d79e3023aa5828600d64d348907 /net/core | |
parent | 9067c722cf6930adf1df2d169de9094dd90b0c33 (diff) |
[NEIGH]: Convert neighbour table modification to new netlink api
Signed-off-by: Thomas Graf <tgraf@suug.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core')
-rw-r--r-- | net/core/neighbour.c | 172 |
1 files changed, 104 insertions, 68 deletions
diff --git a/net/core/neighbour.c b/net/core/neighbour.c index 5490afd23b82..5a0b8f48a099 100644 --- a/net/core/neighbour.c +++ b/net/core/neighbour.c | |||
@@ -1754,28 +1754,61 @@ static inline struct neigh_parms *lookup_neigh_params(struct neigh_table *tbl, | |||
1754 | return NULL; | 1754 | return NULL; |
1755 | } | 1755 | } |
1756 | 1756 | ||
1757 | static struct nla_policy nl_neightbl_policy[NDTA_MAX+1] __read_mostly = { | ||
1758 | [NDTA_NAME] = { .type = NLA_STRING }, | ||
1759 | [NDTA_THRESH1] = { .type = NLA_U32 }, | ||
1760 | [NDTA_THRESH2] = { .type = NLA_U32 }, | ||
1761 | [NDTA_THRESH3] = { .type = NLA_U32 }, | ||
1762 | [NDTA_GC_INTERVAL] = { .type = NLA_U64 }, | ||
1763 | [NDTA_PARMS] = { .type = NLA_NESTED }, | ||
1764 | }; | ||
1765 | |||
1766 | static struct nla_policy nl_ntbl_parm_policy[NDTPA_MAX+1] __read_mostly = { | ||
1767 | [NDTPA_IFINDEX] = { .type = NLA_U32 }, | ||
1768 | [NDTPA_QUEUE_LEN] = { .type = NLA_U32 }, | ||
1769 | [NDTPA_PROXY_QLEN] = { .type = NLA_U32 }, | ||
1770 | [NDTPA_APP_PROBES] = { .type = NLA_U32 }, | ||
1771 | [NDTPA_UCAST_PROBES] = { .type = NLA_U32 }, | ||
1772 | [NDTPA_MCAST_PROBES] = { .type = NLA_U32 }, | ||
1773 | [NDTPA_BASE_REACHABLE_TIME] = { .type = NLA_U64 }, | ||
1774 | [NDTPA_GC_STALETIME] = { .type = NLA_U64 }, | ||
1775 | [NDTPA_DELAY_PROBE_TIME] = { .type = NLA_U64 }, | ||
1776 | [NDTPA_RETRANS_TIME] = { .type = NLA_U64 }, | ||
1777 | [NDTPA_ANYCAST_DELAY] = { .type = NLA_U64 }, | ||
1778 | [NDTPA_PROXY_DELAY] = { .type = NLA_U64 }, | ||
1779 | [NDTPA_LOCKTIME] = { .type = NLA_U64 }, | ||
1780 | }; | ||
1781 | |||
1757 | int neightbl_set(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg) | 1782 | int neightbl_set(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg) |
1758 | { | 1783 | { |
1759 | struct neigh_table *tbl; | 1784 | struct neigh_table *tbl; |
1760 | struct ndtmsg *ndtmsg = NLMSG_DATA(nlh); | 1785 | struct ndtmsg *ndtmsg; |
1761 | struct rtattr **tb = arg; | 1786 | struct nlattr *tb[NDTA_MAX+1]; |
1762 | int err = -EINVAL; | 1787 | int err; |
1763 | 1788 | ||
1764 | if (!tb[NDTA_NAME - 1] || !RTA_PAYLOAD(tb[NDTA_NAME - 1])) | 1789 | err = nlmsg_parse(nlh, sizeof(*ndtmsg), tb, NDTA_MAX, |
1765 | return -EINVAL; | 1790 | nl_neightbl_policy); |
1791 | if (err < 0) | ||
1792 | goto errout; | ||
1793 | |||
1794 | if (tb[NDTA_NAME] == NULL) { | ||
1795 | err = -EINVAL; | ||
1796 | goto errout; | ||
1797 | } | ||
1766 | 1798 | ||
1799 | ndtmsg = nlmsg_data(nlh); | ||
1767 | read_lock(&neigh_tbl_lock); | 1800 | read_lock(&neigh_tbl_lock); |
1768 | for (tbl = neigh_tables; tbl; tbl = tbl->next) { | 1801 | for (tbl = neigh_tables; tbl; tbl = tbl->next) { |
1769 | if (ndtmsg->ndtm_family && tbl->family != ndtmsg->ndtm_family) | 1802 | if (ndtmsg->ndtm_family && tbl->family != ndtmsg->ndtm_family) |
1770 | continue; | 1803 | continue; |
1771 | 1804 | ||
1772 | if (!rtattr_strcmp(tb[NDTA_NAME - 1], tbl->id)) | 1805 | if (nla_strcmp(tb[NDTA_NAME], tbl->id) == 0) |
1773 | break; | 1806 | break; |
1774 | } | 1807 | } |
1775 | 1808 | ||
1776 | if (tbl == NULL) { | 1809 | if (tbl == NULL) { |
1777 | err = -ENOENT; | 1810 | err = -ENOENT; |
1778 | goto errout; | 1811 | goto errout_locked; |
1779 | } | 1812 | } |
1780 | 1813 | ||
1781 | /* | 1814 | /* |
@@ -1784,86 +1817,89 @@ int neightbl_set(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg) | |||
1784 | */ | 1817 | */ |
1785 | write_lock_bh(&tbl->lock); | 1818 | write_lock_bh(&tbl->lock); |
1786 | 1819 | ||
1787 | if (tb[NDTA_THRESH1 - 1]) | 1820 | if (tb[NDTA_PARMS]) { |
1788 | tbl->gc_thresh1 = RTA_GET_U32(tb[NDTA_THRESH1 - 1]); | 1821 | struct nlattr *tbp[NDTPA_MAX+1]; |
1789 | |||
1790 | if (tb[NDTA_THRESH2 - 1]) | ||
1791 | tbl->gc_thresh2 = RTA_GET_U32(tb[NDTA_THRESH2 - 1]); | ||
1792 | |||
1793 | if (tb[NDTA_THRESH3 - 1]) | ||
1794 | tbl->gc_thresh3 = RTA_GET_U32(tb[NDTA_THRESH3 - 1]); | ||
1795 | |||
1796 | if (tb[NDTA_GC_INTERVAL - 1]) | ||
1797 | tbl->gc_interval = RTA_GET_MSECS(tb[NDTA_GC_INTERVAL - 1]); | ||
1798 | |||
1799 | if (tb[NDTA_PARMS - 1]) { | ||
1800 | struct rtattr *tbp[NDTPA_MAX]; | ||
1801 | struct neigh_parms *p; | 1822 | struct neigh_parms *p; |
1802 | u32 ifindex = 0; | 1823 | int i, ifindex = 0; |
1803 | 1824 | ||
1804 | if (rtattr_parse_nested(tbp, NDTPA_MAX, tb[NDTA_PARMS - 1]) < 0) | 1825 | err = nla_parse_nested(tbp, NDTPA_MAX, tb[NDTA_PARMS], |
1805 | goto rtattr_failure; | 1826 | nl_ntbl_parm_policy); |
1827 | if (err < 0) | ||
1828 | goto errout_tbl_lock; | ||
1806 | 1829 | ||
1807 | if (tbp[NDTPA_IFINDEX - 1]) | 1830 | if (tbp[NDTPA_IFINDEX]) |
1808 | ifindex = RTA_GET_U32(tbp[NDTPA_IFINDEX - 1]); | 1831 | ifindex = nla_get_u32(tbp[NDTPA_IFINDEX]); |
1809 | 1832 | ||
1810 | p = lookup_neigh_params(tbl, ifindex); | 1833 | p = lookup_neigh_params(tbl, ifindex); |
1811 | if (p == NULL) { | 1834 | if (p == NULL) { |
1812 | err = -ENOENT; | 1835 | err = -ENOENT; |
1813 | goto rtattr_failure; | 1836 | goto errout_tbl_lock; |
1814 | } | 1837 | } |
1815 | |||
1816 | if (tbp[NDTPA_QUEUE_LEN - 1]) | ||
1817 | p->queue_len = RTA_GET_U32(tbp[NDTPA_QUEUE_LEN - 1]); | ||
1818 | |||
1819 | if (tbp[NDTPA_PROXY_QLEN - 1]) | ||
1820 | p->proxy_qlen = RTA_GET_U32(tbp[NDTPA_PROXY_QLEN - 1]); | ||
1821 | |||
1822 | if (tbp[NDTPA_APP_PROBES - 1]) | ||
1823 | p->app_probes = RTA_GET_U32(tbp[NDTPA_APP_PROBES - 1]); | ||
1824 | |||
1825 | if (tbp[NDTPA_UCAST_PROBES - 1]) | ||
1826 | p->ucast_probes = | ||
1827 | RTA_GET_U32(tbp[NDTPA_UCAST_PROBES - 1]); | ||
1828 | 1838 | ||
1829 | if (tbp[NDTPA_MCAST_PROBES - 1]) | 1839 | for (i = 1; i <= NDTPA_MAX; i++) { |
1830 | p->mcast_probes = | 1840 | if (tbp[i] == NULL) |
1831 | RTA_GET_U32(tbp[NDTPA_MCAST_PROBES - 1]); | 1841 | continue; |
1832 | |||
1833 | if (tbp[NDTPA_BASE_REACHABLE_TIME - 1]) | ||
1834 | p->base_reachable_time = | ||
1835 | RTA_GET_MSECS(tbp[NDTPA_BASE_REACHABLE_TIME - 1]); | ||
1836 | |||
1837 | if (tbp[NDTPA_GC_STALETIME - 1]) | ||
1838 | p->gc_staletime = | ||
1839 | RTA_GET_MSECS(tbp[NDTPA_GC_STALETIME - 1]); | ||
1840 | 1842 | ||
1841 | if (tbp[NDTPA_DELAY_PROBE_TIME - 1]) | 1843 | switch (i) { |
1842 | p->delay_probe_time = | 1844 | case NDTPA_QUEUE_LEN: |
1843 | RTA_GET_MSECS(tbp[NDTPA_DELAY_PROBE_TIME - 1]); | 1845 | p->queue_len = nla_get_u32(tbp[i]); |
1846 | break; | ||
1847 | case NDTPA_PROXY_QLEN: | ||
1848 | p->proxy_qlen = nla_get_u32(tbp[i]); | ||
1849 | break; | ||
1850 | case NDTPA_APP_PROBES: | ||
1851 | p->app_probes = nla_get_u32(tbp[i]); | ||
1852 | break; | ||
1853 | case NDTPA_UCAST_PROBES: | ||
1854 | p->ucast_probes = nla_get_u32(tbp[i]); | ||
1855 | break; | ||
1856 | case NDTPA_MCAST_PROBES: | ||
1857 | p->mcast_probes = nla_get_u32(tbp[i]); | ||
1858 | break; | ||
1859 | case NDTPA_BASE_REACHABLE_TIME: | ||
1860 | p->base_reachable_time = nla_get_msecs(tbp[i]); | ||
1861 | break; | ||
1862 | case NDTPA_GC_STALETIME: | ||
1863 | p->gc_staletime = nla_get_msecs(tbp[i]); | ||
1864 | break; | ||
1865 | case NDTPA_DELAY_PROBE_TIME: | ||
1866 | p->delay_probe_time = nla_get_msecs(tbp[i]); | ||
1867 | break; | ||
1868 | case NDTPA_RETRANS_TIME: | ||
1869 | p->retrans_time = nla_get_msecs(tbp[i]); | ||
1870 | break; | ||
1871 | case NDTPA_ANYCAST_DELAY: | ||
1872 | p->anycast_delay = nla_get_msecs(tbp[i]); | ||
1873 | break; | ||
1874 | case NDTPA_PROXY_DELAY: | ||
1875 | p->proxy_delay = nla_get_msecs(tbp[i]); | ||
1876 | break; | ||
1877 | case NDTPA_LOCKTIME: | ||
1878 | p->locktime = nla_get_msecs(tbp[i]); | ||
1879 | break; | ||
1880 | } | ||
1881 | } | ||
1882 | } | ||
1844 | 1883 | ||
1845 | if (tbp[NDTPA_RETRANS_TIME - 1]) | 1884 | if (tb[NDTA_THRESH1]) |
1846 | p->retrans_time = | 1885 | tbl->gc_thresh1 = nla_get_u32(tb[NDTA_THRESH1]); |
1847 | RTA_GET_MSECS(tbp[NDTPA_RETRANS_TIME - 1]); | ||
1848 | 1886 | ||
1849 | if (tbp[NDTPA_ANYCAST_DELAY - 1]) | 1887 | if (tb[NDTA_THRESH2]) |
1850 | p->anycast_delay = | 1888 | tbl->gc_thresh2 = nla_get_u32(tb[NDTA_THRESH2]); |
1851 | RTA_GET_MSECS(tbp[NDTPA_ANYCAST_DELAY - 1]); | ||
1852 | 1889 | ||
1853 | if (tbp[NDTPA_PROXY_DELAY - 1]) | 1890 | if (tb[NDTA_THRESH3]) |
1854 | p->proxy_delay = | 1891 | tbl->gc_thresh3 = nla_get_u32(tb[NDTA_THRESH3]); |
1855 | RTA_GET_MSECS(tbp[NDTPA_PROXY_DELAY - 1]); | ||
1856 | 1892 | ||
1857 | if (tbp[NDTPA_LOCKTIME - 1]) | 1893 | if (tb[NDTA_GC_INTERVAL]) |
1858 | p->locktime = RTA_GET_MSECS(tbp[NDTPA_LOCKTIME - 1]); | 1894 | tbl->gc_interval = nla_get_msecs(tb[NDTA_GC_INTERVAL]); |
1859 | } | ||
1860 | 1895 | ||
1861 | err = 0; | 1896 | err = 0; |
1862 | 1897 | ||
1863 | rtattr_failure: | 1898 | errout_tbl_lock: |
1864 | write_unlock_bh(&tbl->lock); | 1899 | write_unlock_bh(&tbl->lock); |
1865 | errout: | 1900 | errout_locked: |
1866 | read_unlock(&neigh_tbl_lock); | 1901 | read_unlock(&neigh_tbl_lock); |
1902 | errout: | ||
1867 | return err; | 1903 | return err; |
1868 | } | 1904 | } |
1869 | 1905 | ||