OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "net/udp/udp_socket_win.h" | 5 #include "net/udp/udp_socket_win.h" |
6 | 6 |
7 #include <mstcpip.h> | 7 #include <mstcpip.h> |
8 | 8 |
9 #include "base/callback.h" | 9 #include "base/callback.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
(...skipping 337 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
348 if (rv < 0) | 348 if (rv < 0) |
349 return rv; | 349 return rv; |
350 rv = DoBind(address); | 350 rv = DoBind(address); |
351 if (rv < 0) | 351 if (rv < 0) |
352 return rv; | 352 return rv; |
353 local_address_.reset(); | 353 local_address_.reset(); |
354 return rv; | 354 return rv; |
355 } | 355 } |
356 | 356 |
357 int UDPSocketWin::CreateSocket(const IPEndPoint& address) { | 357 int UDPSocketWin::CreateSocket(const IPEndPoint& address) { |
358 socket_ = WSASocket(address.GetSockAddrFamily(), SOCK_DGRAM, IPPROTO_UDP, | 358 sock_addr_family_ = address.GetSockAddrFamily(); |
359 socket_ = WSASocket(sock_addr_family_, SOCK_DGRAM, IPPROTO_UDP, | |
359 NULL, 0, WSA_FLAG_OVERLAPPED); | 360 NULL, 0, WSA_FLAG_OVERLAPPED); |
360 if (socket_ == INVALID_SOCKET) | 361 if (socket_ == INVALID_SOCKET) |
361 return MapSystemError(WSAGetLastError()); | 362 return MapSystemError(WSAGetLastError()); |
362 core_ = new Core(this); | 363 core_ = new Core(this); |
363 return OK; | 364 return OK; |
364 } | 365 } |
365 | 366 |
366 bool UDPSocketWin::SetReceiveBufferSize(int32 size) { | 367 bool UDPSocketWin::SetReceiveBufferSize(int32 size) { |
367 DCHECK(CalledOnValidThread()); | 368 DCHECK(CalledOnValidThread()); |
368 int rv = setsockopt(socket_, SOL_SOCKET, SO_RCVBUF, | 369 int rv = setsockopt(socket_, SOL_SOCKET, SO_RCVBUF, |
(...skipping 208 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
577 if (rv < 0) | 578 if (rv < 0) |
578 return MapSystemError(errno); | 579 return MapSystemError(errno); |
579 } | 580 } |
580 if (socket_options_ & SOCKET_OPTION_BROADCAST) { | 581 if (socket_options_ & SOCKET_OPTION_BROADCAST) { |
581 int rv = setsockopt(socket_, SOL_SOCKET, SO_BROADCAST, | 582 int rv = setsockopt(socket_, SOL_SOCKET, SO_BROADCAST, |
582 reinterpret_cast<const char*>(&true_value), | 583 reinterpret_cast<const char*>(&true_value), |
583 sizeof(true_value)); | 584 sizeof(true_value)); |
584 if (rv < 0) | 585 if (rv < 0) |
585 return MapSystemError(errno); | 586 return MapSystemError(errno); |
586 } | 587 } |
588 if (multicast_time_to_live_ != 1) { | |
589 int rv = SetMulticastTimeToLive(multicast_time_to_live_); | |
590 if (rv != OK) | |
591 return rv; | |
592 } | |
593 if (!multicast_loopback_mode_) { | |
594 int rv = SetMulticastLoopbackMode(multicast_loopback_mode_); | |
595 if (rv != OK) | |
596 return rv; | |
597 } | |
587 return OK; | 598 return OK; |
588 } | 599 } |
589 | 600 |
590 int UDPSocketWin::DoBind(const IPEndPoint& address) { | 601 int UDPSocketWin::DoBind(const IPEndPoint& address) { |
591 SockaddrStorage storage; | 602 SockaddrStorage storage; |
592 if (!address.ToSockAddr(storage.addr, &storage.addr_len)) | 603 if (!address.ToSockAddr(storage.addr, &storage.addr_len)) |
593 return ERR_UNEXPECTED; | 604 return ERR_UNEXPECTED; |
594 int rv = bind(socket_, storage.addr, storage.addr_len); | 605 int rv = bind(socket_, storage.addr, storage.addr_len); |
595 return rv < 0 ? MapSystemError(WSAGetLastError()) : rv; | 606 return rv < 0 ? MapSystemError(WSAGetLastError()) : rv; |
596 } | 607 } |
(...skipping 10 matching lines...) Expand all Loading... | |
607 return rv; | 618 return rv; |
608 } | 619 } |
609 return DoBind(IPEndPoint(ip, 0)); | 620 return DoBind(IPEndPoint(ip, 0)); |
610 } | 621 } |
611 | 622 |
612 bool UDPSocketWin::ReceiveAddressToIPEndpoint(IPEndPoint* address) const { | 623 bool UDPSocketWin::ReceiveAddressToIPEndpoint(IPEndPoint* address) const { |
613 SockaddrStorage& storage = core_->recv_addr_storage_; | 624 SockaddrStorage& storage = core_->recv_addr_storage_; |
614 return address->FromSockAddr(storage.addr, storage.addr_len); | 625 return address->FromSockAddr(storage.addr, storage.addr_len); |
615 } | 626 } |
616 | 627 |
628 | |
629 int UDPSocketWin::JoinGroup( | |
630 const net::IPAddressNumber& group_address) const { | |
631 DCHECK(CalledOnValidThread()); | |
632 DCHECK(is_connected()); | |
633 int rv = -1; | |
634 switch(group_address.size()) { | |
mmenke
2013/04/12 21:07:41
Space after switch.
Bei Zhang
2013/04/15 22:30:26
Done.
| |
635 case kIPv4AddressSize: { | |
636 if (sock_addr_family_ != AF_INET) { | |
637 return ERR_ADDRESS_INVALID; | |
638 } | |
639 ip_mreq mreq; | |
640 memset(&mreq, 0, sizeof(mreq)); | |
641 memcpy(&mreq.imr_multiaddr, &group_address[0], kIPv4AddressSize); | |
642 rv = setsockopt(socket_, IPPROTO_IP, IP_ADD_MEMBERSHIP, | |
643 reinterpret_cast<const char*>(&mreq), | |
644 sizeof(mreq)); | |
645 break; | |
646 } | |
647 case kIPv6AddressSize: { | |
648 if (sock_addr_family_ != AF_INET6) { | |
649 return ERR_ADDRESS_INVALID; | |
650 } | |
651 ipv6_mreq mreq; | |
652 memset(&mreq, 0, sizeof(mreq)); | |
653 memcpy(&mreq.ipv6mr_multiaddr, &group_address[0], kIPv6AddressSize); | |
654 rv = setsockopt(socket_, IPPROTO_IPV6, IPV6_ADD_MEMBERSHIP, | |
655 reinterpret_cast<const char*>(&mreq), | |
656 sizeof(mreq)); | |
657 break; | |
658 } | |
659 } | |
660 return MapSystemError(rv); | |
661 } | |
662 | |
663 int UDPSocketWin::LeaveGroup( | |
664 const net::IPAddressNumber& group_address) const { | |
665 DCHECK(CalledOnValidThread()); | |
666 DCHECK(is_connected()); | |
667 int rv = -1; | |
668 switch(group_address.size()) { | |
669 case kIPv4AddressSize: { | |
670 if (sock_addr_family_ != AF_INET) { | |
671 return ERR_ADDRESS_INVALID; | |
672 } | |
673 ip_mreq mreq; | |
674 memset(&mreq, 0, sizeof(mreq)); | |
675 memcpy(&mreq.imr_multiaddr, &group_address[0], kIPv4AddressSize); | |
676 rv = setsockopt(socket_, IPPROTO_IP, IP_DROP_MEMBERSHIP, | |
677 reinterpret_cast<const char*>(&mreq), | |
678 sizeof(mreq)); | |
679 break; | |
680 } | |
681 case kIPv6AddressSize: { | |
682 if (sock_addr_family_ != AF_INET6) { | |
683 return ERR_ADDRESS_INVALID; | |
684 } | |
685 ipv6_mreq mreq; | |
686 memset(&mreq, 0, sizeof(mreq)); | |
687 memcpy(&mreq.ipv6mr_multiaddr, &group_address[0], kIPv6AddressSize); | |
688 rv = setsockopt(socket_, IPPROTO_IPV6, IP_DROP_MEMBERSHIP, | |
689 reinterpret_cast<const char*>(&mreq), | |
690 sizeof(mreq)); | |
691 break; | |
692 } | |
693 } | |
694 return MapSystemError(rv); | |
695 } | |
696 | |
697 int UDPSocketWin::SetMulticastTimeToLive(int timeToLive) { | |
mmenke
2013/04/12 21:07:41
time_to_live
Bei Zhang
2013/04/15 22:30:26
Done.
| |
698 DCHECK(CalledOnValidThread()); | |
699 if(is_connected()) { | |
mmenke
2013/04/12 21:07:41
Space after if
Bei Zhang
2013/04/15 22:30:26
Done.
| |
700 if (timeToLive < 0 || timeToLive > 255) { | |
701 return ERR_INVALID_ARGUMENT; | |
702 } | |
703 uint8 ttl = timeToLive; | |
704 int ip_family = sock_addr_family_ == AF_INET ? IPPROTO_IP : IPPROTO_IPV6; | |
705 return MapSystemError(setsockopt(socket_, | |
706 ip_family, | |
707 IP_MULTICAST_TTL, | |
708 reinterpret_cast<const char*>(&ttl), | |
709 sizeof(ttl))); | |
710 } else { | |
711 multicast_time_to_live_ = timeToLive; | |
712 return OK; | |
713 } | |
714 | |
mmenke
2013/04/12 21:07:41
Remove blank line.
Bei Zhang
2013/04/15 22:30:26
Done.
| |
715 } | |
716 | |
717 int UDPSocketWin::SetMulticastLoopbackMode(bool loopback) { | |
718 DCHECK(CalledOnValidThread()); | |
719 if(is_connected()) { | |
mmenke
2013/04/12 21:07:41
Space after if
Bei Zhang
2013/04/15 22:30:26
Done.
| |
720 uint8 loop = loopback; | |
721 int ip_family = sock_addr_family_ == AF_INET ? IPPROTO_IP : IPPROTO_IPV6; | |
722 return MapSystemError(setsockopt(socket_, | |
723 ip_family, | |
724 IP_MULTICAST_LOOP, | |
725 reinterpret_cast<const char*>(&loop), | |
726 sizeof(loop))); | |
mmenke
2013/04/12 21:07:41
4-space indent.
Bei Zhang
2013/04/15 22:30:26
Done.
| |
727 } else { | |
728 multicast_loopback_mode_ = loopback; | |
729 return OK; | |
730 } | |
731 } | |
732 | |
617 } // namespace net | 733 } // namespace net |
OLD | NEW |