Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
[deliverable/linux.git] / net / ipv4 / udp.c
index f87a8eb76f3be1fdc83e4e32f0e057d923205035..a15c8fb653af2e53952be97d1ce87d3f697fc544 100644 (file)
@@ -909,20 +909,14 @@ int udp_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg,
                rt = (struct rtable *)sk_dst_check(sk, 0);
 
        if (rt == NULL) {
-               struct flowi4 fl4 = {
-                       .flowi4_oif = ipc.oif,
-                       .flowi4_mark = sk->sk_mark,
-                       .daddr = faddr,
-                       .saddr = saddr,
-                       .flowi4_tos = tos,
-                       .flowi4_proto = sk->sk_protocol,
-                       .flowi4_flags = (inet_sk_flowi_flags(sk) |
-                                        FLOWI_FLAG_CAN_SLEEP),
-                       .fl4_sport = inet->inet_sport,
-                       .fl4_dport = dport,
-               };
+               struct flowi4 fl4;
                struct net *net = sock_net(sk);
 
+               flowi4_init_output(&fl4, ipc.oif, sk->sk_mark, tos,
+                                  RT_SCOPE_UNIVERSE, sk->sk_protocol,
+                                  inet_sk_flowi_flags(sk)|FLOWI_FLAG_CAN_SLEEP,
+                                  faddr, saddr, dport, inet->inet_sport);
+
                security_sk_classify_flow(sk, flowi4_to_flowi(&fl4));
                rt = ip_route_output_flow(net, &fl4, sk);
                if (IS_ERR(rt)) {
This page took 0.024816 seconds and 5 git commands to generate.