123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205 |
- //
- // Copyright (C) 2013 The Android Open Source Project
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- //
- #ifndef UPDATE_ENGINE_COMMON_CONSTANTS_H_
- #define UPDATE_ENGINE_COMMON_CONSTANTS_H_
- namespace chromeos_update_engine {
- // Directory for AU prefs that are preserved across powerwash.
- extern const char kPowerwashSafePrefsSubDirectory[];
- // The location where we store the AU preferences (state etc).
- extern const char kPrefsSubDirectory[];
- // Path to the post install command, relative to the partition.
- extern const char kPostinstallDefaultScript[];
- // Path to the stateful partition on the root filesystem.
- extern const char kStatefulPartition[];
- // Constants related to preferences.
- extern const char kPrefsAttemptInProgress[];
- extern const char kPrefsBackoffExpiryTime[];
- extern const char kPrefsBootId[];
- extern const char kPrefsCurrentBytesDownloaded[];
- extern const char kPrefsCurrentResponseSignature[];
- extern const char kPrefsCurrentUrlFailureCount[];
- extern const char kPrefsCurrentUrlIndex[];
- extern const char kPrefsDailyMetricsLastReportedAt[];
- extern const char kPrefsDeltaUpdateFailures[];
- extern const char kPrefsDynamicPartitionMetadataUpdated[];
- extern const char kPrefsFullPayloadAttemptNumber[];
- extern const char kPrefsInstallDateDays[];
- extern const char kPrefsLastActivePingDay[];
- extern const char kPrefsLastRollCallPingDay[];
- extern const char kPrefsManifestMetadataSize[];
- extern const char kPrefsManifestSignatureSize[];
- extern const char kPrefsMetricsAttemptLastReportingTime[];
- extern const char kPrefsMetricsCheckLastReportingTime[];
- extern const char kPrefsNoIgnoreBackoff[];
- extern const char kPrefsNumReboots[];
- extern const char kPrefsNumResponsesSeen[];
- extern const char kPrefsOmahaCohort[];
- extern const char kPrefsOmahaCohortHint[];
- extern const char kPrefsOmahaCohortName[];
- extern const char kPrefsOmahaEolStatus[];
- extern const char kPrefsP2PEnabled[];
- extern const char kPrefsP2PFirstAttemptTimestamp[];
- extern const char kPrefsP2PNumAttempts[];
- extern const char kPrefsPayloadAttemptNumber[];
- extern const char kPrefsPostInstallSucceeded[];
- extern const char kPrefsPreviousVersion[];
- extern const char kPrefsResumedUpdateFailures[];
- extern const char kPrefsRollbackHappened[];
- extern const char kPrefsRollbackVersion[];
- extern const char kPrefsChannelOnSlotPrefix[];
- extern const char kPrefsSystemUpdatedMarker[];
- extern const char kPrefsTargetVersionAttempt[];
- extern const char kPrefsTargetVersionInstalledFrom[];
- extern const char kPrefsTargetVersionUniqueId[];
- extern const char kPrefsTotalBytesDownloaded[];
- extern const char kPrefsUpdateCheckCount[];
- extern const char kPrefsUpdateCheckResponseHash[];
- extern const char kPrefsUpdateCompletedBootTime[];
- extern const char kPrefsUpdateCompletedOnBootId[];
- extern const char kPrefsUpdateDurationUptime[];
- extern const char kPrefsUpdateFirstSeenAt[];
- extern const char kPrefsUpdateOverCellularPermission[];
- extern const char kPrefsUpdateOverCellularTargetVersion[];
- extern const char kPrefsUpdateOverCellularTargetSize[];
- extern const char kPrefsUpdateServerCertificate[];
- extern const char kPrefsUpdateStateNextDataLength[];
- extern const char kPrefsUpdateStateNextDataOffset[];
- extern const char kPrefsUpdateStateNextOperation[];
- extern const char kPrefsUpdateStatePayloadIndex[];
- extern const char kPrefsUpdateStateSHA256Context[];
- extern const char kPrefsUpdateStateSignatureBlob[];
- extern const char kPrefsUpdateStateSignedSHA256Context[];
- extern const char kPrefsUpdateBootTimestampStart[];
- extern const char kPrefsUpdateTimestampStart[];
- extern const char kPrefsUrlSwitchCount[];
- extern const char kPrefsVerityWritten[];
- extern const char kPrefsWallClockScatteringWaitPeriod[];
- extern const char kPrefsWallClockStagingWaitPeriod[];
- // Keys used when storing and loading payload properties.
- extern const char kPayloadPropertyFileSize[];
- extern const char kPayloadPropertyFileHash[];
- extern const char kPayloadPropertyMetadataSize[];
- extern const char kPayloadPropertyMetadataHash[];
- extern const char kPayloadPropertyAuthorization[];
- extern const char kPayloadPropertyUserAgent[];
- extern const char kPayloadPropertyPowerwash[];
- extern const char kPayloadPropertyNetworkId[];
- extern const char kPayloadPropertySwitchSlotOnReboot[];
- extern const char kPayloadPropertyRunPostInstall[];
- // A download source is any combination of protocol and server (that's of
- // interest to us when looking at UMA metrics) using which we may download
- // the payload.
- typedef enum {
- kDownloadSourceHttpsServer, // UMA Binary representation: 0001
- kDownloadSourceHttpServer, // UMA Binary representation: 0010
- kDownloadSourceHttpPeer, // UMA Binary representation: 0100
- // Note: Add new sources only above this line.
- kNumDownloadSources
- } DownloadSource;
- // A payload can be a Full or Delta payload. In some cases, a Full payload is
- // used even when a Delta payload was available for the update, called here
- // ForcedFull. The PayloadType enum is only used to send UMA metrics about the
- // successfully applied payload.
- typedef enum {
- kPayloadTypeFull,
- kPayloadTypeDelta,
- kPayloadTypeForcedFull,
- // Note: Add new payload types only above this line.
- kNumPayloadTypes
- } PayloadType;
- // Maximum number of times we'll allow using p2p for the same update payload.
- const int kMaxP2PAttempts = 10;
- // Maximum wallclock time we allow attempting to update using p2p for
- // the same update payload - five days.
- const int kMaxP2PAttemptTimeSeconds = 5 * 24 * 60 * 60;
- // The maximum amount of time to spend waiting for p2p-client(1) to
- // return while waiting in line to use the LAN - six hours.
- const int kMaxP2PNetworkWaitTimeSeconds = 6 * 60 * 60;
- // The maximum number of payload files to keep in /var/cache/p2p.
- const int kMaxP2PFilesToKeep = 3;
- // The maximum number of days to keep a p2p file;
- const int kMaxP2PFileAgeDays = 5;
- // The default number of UMA buckets for metrics.
- const int kNumDefaultUmaBuckets = 50;
- // General constants
- const int kNumBytesInOneMiB = 1024 * 1024;
- // Number of redirects allowed when downloading.
- const int kDownloadMaxRedirects = 10;
- // The minimum average speed that downloads must sustain...
- //
- // This is set low because some devices may have very poor
- // connectivity and we want to make as much forward progress as
- // possible. For p2p this is high (25 kB/second) since we can assume
- // high bandwidth (same LAN) and we want to fail fast.
- const int kDownloadLowSpeedLimitBps = 1;
- const int kDownloadP2PLowSpeedLimitBps = 25 * 1000;
- // ... measured over this period.
- //
- // For non-official builds (e.g. typically built on a developer's
- // workstation and served via devserver) bump this since it takes time
- // for the workstation to generate the payload. For normal operation
- // and p2p, make this relatively low since we want to fail fast in
- // those cases.
- const int kDownloadLowSpeedTimeSeconds = 30;
- const int kDownloadDevModeLowSpeedTimeSeconds = 180;
- const int kDownloadP2PLowSpeedTimeSeconds = 60;
- // The maximum amount of HTTP server reconnect attempts.
- //
- // This is set high in order to maximize the attempt's chance of
- // succeeding. When using p2p, this is low in order to fail fast.
- const int kDownloadMaxRetryCount = 20;
- const int kDownloadMaxRetryCountOobeNotComplete = 3;
- const int kDownloadMaxRetryCountInteractive = 3;
- const int kDownloadP2PMaxRetryCount = 5;
- // The connect timeout, in seconds.
- //
- // This is set high because some devices may have very poor
- // connectivity and we may be using HTTPS which involves complicated
- // multi-roundtrip setup. For p2p, this is set low because we can
- // the server is on the same LAN and we want to fail fast.
- const int kDownloadConnectTimeoutSeconds = 30;
- const int kDownloadP2PConnectTimeoutSeconds = 5;
- // Size in bytes of SHA256 hash.
- const int kSHA256Size = 32;
- } // namespace chromeos_update_engine
- #endif // UPDATE_ENGINE_COMMON_CONSTANTS_H_
|