| OLD | NEW |
| 1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 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 // See header file for description of class | 5 // See header file for description of class |
| 6 | 6 |
| 7 #include "chrome/browser/net/dns_host_info.h" | 7 #include "chrome/browser/net/dns_host_info.h" |
| 8 | 8 |
| 9 #include <math.h> | 9 #include <math.h> |
| 10 | 10 |
| (...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 82 SetMotivation(motivation); | 82 SetMotivation(motivation); |
| 83 GetDuration(); // Set time_ | 83 GetDuration(); // Set time_ |
| 84 DLogResultsStats("DNS Prefetch in queue"); | 84 DLogResultsStats("DNS Prefetch in queue"); |
| 85 } | 85 } |
| 86 | 86 |
| 87 void DnsHostInfo::SetAssignedState() { | 87 void DnsHostInfo::SetAssignedState() { |
| 88 DCHECK(QUEUED == state_); | 88 DCHECK(QUEUED == state_); |
| 89 state_ = ASSIGNED; | 89 state_ = ASSIGNED; |
| 90 queue_duration_ = GetDuration(); | 90 queue_duration_ = GetDuration(); |
| 91 DLogResultsStats("DNS Prefetch assigned"); | 91 DLogResultsStats("DNS Prefetch assigned"); |
| 92 UMA_HISTOGRAM_TIMES(L"DNS.PrefetchQueue", queue_duration_); | 92 UMA_HISTOGRAM_TIMES("DNS.PrefetchQueue", queue_duration_); |
| 93 } | 93 } |
| 94 | 94 |
| 95 void DnsHostInfo::SetPendingDeleteState() { | 95 void DnsHostInfo::SetPendingDeleteState() { |
| 96 DCHECK(ASSIGNED == state_ || ASSIGNED_BUT_MARKED == state_); | 96 DCHECK(ASSIGNED == state_ || ASSIGNED_BUT_MARKED == state_); |
| 97 state_ = ASSIGNED_BUT_MARKED; | 97 state_ = ASSIGNED_BUT_MARKED; |
| 98 } | 98 } |
| 99 | 99 |
| 100 void DnsHostInfo::SetFoundState() { | 100 void DnsHostInfo::SetFoundState() { |
| 101 DCHECK(ASSIGNED == state_); | 101 DCHECK(ASSIGNED == state_); |
| 102 state_ = FOUND; | 102 state_ = FOUND; |
| 103 resolve_duration_ = GetDuration(); | 103 resolve_duration_ = GetDuration(); |
| 104 if (kMaxNonNetworkDnsLookupDuration <= resolve_duration_) { | 104 if (kMaxNonNetworkDnsLookupDuration <= resolve_duration_) { |
| 105 UMA_HISTOGRAM_LONG_TIMES(L"DNS.PrefetchFoundNameL", resolve_duration_); | 105 UMA_HISTOGRAM_LONG_TIMES("DNS.PrefetchFoundNameL", resolve_duration_); |
| 106 // Record potential beneficial time, and maybe we'll get a cache hit. | 106 // Record potential beneficial time, and maybe we'll get a cache hit. |
| 107 // We keep the maximum, as the warming we did earlier may still be | 107 // We keep the maximum, as the warming we did earlier may still be |
| 108 // helping with a cache upstream in DNS resolution. | 108 // helping with a cache upstream in DNS resolution. |
| 109 benefits_remaining_ = std::max(resolve_duration_, benefits_remaining_); | 109 benefits_remaining_ = std::max(resolve_duration_, benefits_remaining_); |
| 110 } | 110 } |
| 111 sequence_number_ = sequence_counter++; | 111 sequence_number_ = sequence_counter++; |
| 112 DLogResultsStats("DNS PrefetchFound"); | 112 DLogResultsStats("DNS PrefetchFound"); |
| 113 } | 113 } |
| 114 | 114 |
| 115 void DnsHostInfo::SetNoSuchNameState() { | 115 void DnsHostInfo::SetNoSuchNameState() { |
| 116 DCHECK(ASSIGNED == state_); | 116 DCHECK(ASSIGNED == state_); |
| 117 state_ = NO_SUCH_NAME; | 117 state_ = NO_SUCH_NAME; |
| 118 resolve_duration_ = GetDuration(); | 118 resolve_duration_ = GetDuration(); |
| 119 if (kMaxNonNetworkDnsLookupDuration <= resolve_duration_) { | 119 if (kMaxNonNetworkDnsLookupDuration <= resolve_duration_) { |
| 120 DHISTOGRAM_TIMES(L"DNS.PrefetchNotFoundName", resolve_duration_); | 120 DHISTOGRAM_TIMES("DNS.PrefetchNotFoundName", resolve_duration_); |
| 121 // Record potential beneficial time, and maybe we'll get a cache hit. | 121 // Record potential beneficial time, and maybe we'll get a cache hit. |
| 122 benefits_remaining_ = std::max(resolve_duration_, benefits_remaining_); | 122 benefits_remaining_ = std::max(resolve_duration_, benefits_remaining_); |
| 123 } | 123 } |
| 124 sequence_number_ = sequence_counter++; | 124 sequence_number_ = sequence_counter++; |
| 125 DLogResultsStats("DNS PrefetchNotFound"); | 125 DLogResultsStats("DNS PrefetchNotFound"); |
| 126 } | 126 } |
| 127 | 127 |
| 128 void DnsHostInfo::SetStartedState() { | 128 void DnsHostInfo::SetStartedState() { |
| 129 DCHECK(PENDING == state_); | 129 DCHECK(PENDING == state_); |
| 130 state_ = STARTED; | 130 state_ = STARTED; |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 169 // Compare the actual navigation DNS latency found in navigation_info, to the | 169 // Compare the actual navigation DNS latency found in navigation_info, to the |
| 170 // previously prefetched info. | 170 // previously prefetched info. |
| 171 DnsBenefit DnsHostInfo::AccruePrefetchBenefits(DnsHostInfo* navigation_info) { | 171 DnsBenefit DnsHostInfo::AccruePrefetchBenefits(DnsHostInfo* navigation_info) { |
| 172 DCHECK(FINISHED == navigation_info->state_ || | 172 DCHECK(FINISHED == navigation_info->state_ || |
| 173 FINISHED_UNRESOLVED == navigation_info->state_); | 173 FINISHED_UNRESOLVED == navigation_info->state_); |
| 174 DCHECK(0 == navigation_info->hostname_.compare(hostname_.data())); | 174 DCHECK(0 == navigation_info->hostname_.compare(hostname_.data())); |
| 175 | 175 |
| 176 if ((0 == benefits_remaining_.InMilliseconds()) || | 176 if ((0 == benefits_remaining_.InMilliseconds()) || |
| 177 (FOUND != state_ && NO_SUCH_NAME != state_)) { | 177 (FOUND != state_ && NO_SUCH_NAME != state_)) { |
| 178 if (FINISHED == navigation_info->state_) | 178 if (FINISHED == navigation_info->state_) |
| 179 UMA_HISTOGRAM_LONG_TIMES(L"DNS.IndependentNavigation", | 179 UMA_HISTOGRAM_LONG_TIMES("DNS.IndependentNavigation", |
| 180 navigation_info->resolve_duration_); | 180 navigation_info->resolve_duration_); |
| 181 else | 181 else |
| 182 UMA_HISTOGRAM_LONG_TIMES(L"DNS.IndependentFailedNavigation", | 182 UMA_HISTOGRAM_LONG_TIMES("DNS.IndependentFailedNavigation", |
| 183 navigation_info->resolve_duration_); | 183 navigation_info->resolve_duration_); |
| 184 return PREFETCH_NO_BENEFIT; | 184 return PREFETCH_NO_BENEFIT; |
| 185 } | 185 } |
| 186 | 186 |
| 187 TimeDelta benefit = benefits_remaining_ - navigation_info->resolve_duration_; | 187 TimeDelta benefit = benefits_remaining_ - navigation_info->resolve_duration_; |
| 188 navigation_info->benefits_remaining_ = benefits_remaining_; | 188 navigation_info->benefits_remaining_ = benefits_remaining_; |
| 189 benefits_remaining_ = TimeDelta(); // We used up all our benefits here. | 189 benefits_remaining_ = TimeDelta(); // We used up all our benefits here. |
| 190 | 190 |
| 191 navigation_info->motivation_ = motivation_; | 191 navigation_info->motivation_ = motivation_; |
| 192 if (LEARNED_REFERAL_MOTIVATED == motivation_ || | 192 if (LEARNED_REFERAL_MOTIVATED == motivation_ || |
| 193 STATIC_REFERAL_MOTIVATED == motivation_) | 193 STATIC_REFERAL_MOTIVATED == motivation_) |
| 194 navigation_info->referring_hostname_ = referring_hostname_; | 194 navigation_info->referring_hostname_ = referring_hostname_; |
| 195 | 195 |
| 196 if (navigation_info->resolve_duration_ > kMaxNonNetworkDnsLookupDuration) { | 196 if (navigation_info->resolve_duration_ > kMaxNonNetworkDnsLookupDuration) { |
| 197 // Our precache effort didn't help since HTTP stack hit the network. | 197 // Our precache effort didn't help since HTTP stack hit the network. |
| 198 UMA_HISTOGRAM_LONG_TIMES(L"DNS.PrefetchCacheEvictionL", resolve_duration_); | 198 UMA_HISTOGRAM_LONG_TIMES("DNS.PrefetchCacheEvictionL", resolve_duration_); |
| 199 DLogResultsStats("DNS PrefetchCacheEviction"); | 199 DLogResultsStats("DNS PrefetchCacheEviction"); |
| 200 return PREFETCH_CACHE_EVICTION; | 200 return PREFETCH_CACHE_EVICTION; |
| 201 } | 201 } |
| 202 | 202 |
| 203 if (NO_SUCH_NAME == state_) { | 203 if (NO_SUCH_NAME == state_) { |
| 204 UMA_HISTOGRAM_LONG_TIMES(L"DNS.PrefetchNegativeHitL", benefit); | 204 UMA_HISTOGRAM_LONG_TIMES("DNS.PrefetchNegativeHitL", benefit); |
| 205 DLogResultsStats("DNS PrefetchNegativeHit"); | 205 DLogResultsStats("DNS PrefetchNegativeHit"); |
| 206 return PREFETCH_NAME_NONEXISTANT; | 206 return PREFETCH_NAME_NONEXISTANT; |
| 207 } | 207 } |
| 208 | 208 |
| 209 DCHECK_EQ(FOUND, state_); | 209 DCHECK_EQ(FOUND, state_); |
| 210 if (LEARNED_REFERAL_MOTIVATED == motivation_ || | 210 if (LEARNED_REFERAL_MOTIVATED == motivation_ || |
| 211 STATIC_REFERAL_MOTIVATED == motivation_) { | 211 STATIC_REFERAL_MOTIVATED == motivation_) { |
| 212 UMA_HISTOGRAM_TIMES(L"DNS.PrefetchReferredPositiveHit", benefit); | 212 UMA_HISTOGRAM_TIMES("DNS.PrefetchReferredPositiveHit", benefit); |
| 213 DLogResultsStats("DNS PrefetchReferredPositiveHit"); | 213 DLogResultsStats("DNS PrefetchReferredPositiveHit"); |
| 214 } else { | 214 } else { |
| 215 UMA_HISTOGRAM_LONG_TIMES(L"DNS.PrefetchPositiveHitL", benefit); | 215 UMA_HISTOGRAM_LONG_TIMES("DNS.PrefetchPositiveHitL", benefit); |
| 216 DLogResultsStats("DNS PrefetchPositiveHit"); | 216 DLogResultsStats("DNS PrefetchPositiveHit"); |
| 217 } | 217 } |
| 218 return PREFETCH_NAME_FOUND; | 218 return PREFETCH_NAME_FOUND; |
| 219 } | 219 } |
| 220 | 220 |
| 221 void DnsHostInfo::DLogResultsStats(const char* message) const { | 221 void DnsHostInfo::DLogResultsStats(const char* message) const { |
| 222 if (!detailed_logging_enabled) | 222 if (!detailed_logging_enabled) |
| 223 return; | 223 return; |
| 224 DLOG(INFO) << "\t" << message << "\tq=" | 224 DLOG(INFO) << "\t" << message << "\tq=" |
| 225 << queue_duration().InMilliseconds() << "ms,\tr=" | 225 << queue_duration().InMilliseconds() << "ms,\tr=" |
| (...skipping 175 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 401 | 401 |
| 402 case LEARNED_REFERAL_MOTIVATED: | 402 case LEARNED_REFERAL_MOTIVATED: |
| 403 return RemoveJs(referring_hostname_); | 403 return RemoveJs(referring_hostname_); |
| 404 | 404 |
| 405 default: | 405 default: |
| 406 return ""; | 406 return ""; |
| 407 } | 407 } |
| 408 } | 408 } |
| 409 | 409 |
| 410 } // namespace chrome_browser_net | 410 } // namespace chrome_browser_net |
| 411 | |
| OLD | NEW |