// This file is part of BOINC. // http://boinc.berkeley.edu // Copyright (C) 2022 University of California // // BOINC is free software; you can redistribute it and/or modify it // under the terms of the GNU Lesser General Public License // as published by the Free Software Foundation, // either version 3 of the License, or (at your option) any later version. // // BOINC is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. // See the GNU Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public License // along with BOINC. If not, see . #ifndef BOINC_PREFS_H #define BOINC_PREFS_H #include #include "common_defs.h" #include "miofile.h" #include "parse.h" // global prefs are maintained as follows: // 1) a "global_prefs.xml" file, which stores the "network" prefs; // it's maintained by communication with scheduling servers // or project managers // 2) a "global_prefs_override.xml" file, which can be edited manually // or via a GUI. // For the prefs that it specifies, it overrides the network prefs. // A struct with one bool per pref. // This is passed in GUI RPCs (get/set_global_prefs_override_struct) // to indicate which prefs are (or should be) specified in the override file // struct GLOBAL_PREFS_MASK { bool battery_charge_min_pct; bool battery_max_temperature; bool confirm_before_connecting; bool cpu_scheduling_period_minutes; bool cpu_usage_limit; bool daily_xfer_limit_mb; bool daily_xfer_period_days; bool disk_interval; bool disk_max_used_gb; bool disk_max_used_pct; bool disk_min_free_gb; bool dont_verify_images; bool end_hour; bool hangup_if_dialed; bool idle_time_to_run; bool leave_apps_in_memory; bool max_bytes_sec_down; bool max_bytes_sec_up; bool max_ncpus; bool max_ncpus_pct; bool net_end_hour; bool net_start_hour; bool network_wifi_only; bool niu_cpu_usage_limit; bool niu_max_ncpus_pct; bool niu_suspend_cpu_usage; bool ram_max_used_busy_frac; bool ram_max_used_idle_frac; bool run_if_user_active; bool run_gpu_if_user_active; bool run_on_batteries; bool start_hour; bool suspend_cpu_usage; bool suspend_if_no_recent_input; bool vm_max_used_frac; bool work_buf_additional_days; bool work_buf_min_days; GLOBAL_PREFS_MASK(DUMMY_TYPE){} void clear() { static const GLOBAL_PREFS_MASK x(DUMMY); *this = x; } GLOBAL_PREFS_MASK() { clear(); } bool are_prefs_set(); bool are_simple_prefs_set(); void set_all(); }; // 0..24 // run always if start==end or start==0, end=24 // don't run at all if start=24, end=0 // struct TIME_SPAN { bool present; double start_hour; double end_hour; enum TimeMode { Always = 7000, Never, Between }; TIME_SPAN() : present(false), start_hour(0), end_hour(0) {} TIME_SPAN(double start, double end) : present(false), start_hour(start), end_hour(end) {} bool suspended(double hour) const; TimeMode mode() const; }; struct WEEK_PREFS { TIME_SPAN days[7]; WEEK_PREFS() {} void clear() { static const WEEK_PREFS init; *this = init; } void set(int day, double start, double end); void set(int day, TIME_SPAN* time); void unset(int day); }; struct TIME_PREFS : public TIME_SPAN { WEEK_PREFS week; TIME_PREFS() {} TIME_PREFS(double start, double end) { start_hour = start; end_hour = end; } void clear(); bool suspended(double t); }; struct GLOBAL_PREFS { double mod_time; double battery_charge_min_pct; // Android double battery_max_temperature; // Android bool confirm_before_connecting; double cpu_scheduling_period_minutes; // length of a time slice. // scheduling happens more often. TIME_PREFS cpu_times; double cpu_usage_limit; // for CPU throttling. This is a percentage 0..100 double daily_xfer_limit_mb; int daily_xfer_period_days; double disk_interval; double disk_max_used_gb; double disk_max_used_pct; double disk_min_free_gb; bool dont_verify_images; bool hangup_if_dialed; double idle_time_to_run; bool leave_apps_in_memory; double max_bytes_sec_down; double max_bytes_sec_up; int max_ncpus; double max_ncpus_pct; TIME_PREFS net_times; bool network_wifi_only; // introduced with Android. Do network communication only when on Wifi, // not on public cell networks. // CAUTION: this only applies to file transfers. // scheduler RPCs are made regardless of this preference. double niu_cpu_usage_limit; double niu_max_ncpus_pct; double niu_suspend_cpu_usage; double ram_max_used_busy_frac; double ram_max_used_idle_frac; bool run_gpu_if_user_active; bool run_if_user_active; bool run_on_batteries; // poorly named; what it really means is: // if false, suspend while on batteries double suspend_cpu_usage; double suspend_if_no_recent_input; double vm_max_used_frac; double work_buf_additional_days; double work_buf_min_days; char source_project[256]; char source_scheduler[256]; bool host_specific; // an account manager can set this; if set, don't propagate bool override_file_present; bool need_idle_state; // whether idle state makes any difference GLOBAL_PREFS(); void defaults(); void enabled_defaults(); void init(); void init_bools(); int parse(XML_PARSER&, const char* venue, bool& found_venue, GLOBAL_PREFS_MASK& mask); int parse_day(XML_PARSER&); int parse_override(XML_PARSER&, const char* venue, bool& found_venue, GLOBAL_PREFS_MASK& mask); int parse_file(const char* filename, const char* venue, bool& found_venue); int write(MIOFILE&); int write_subset(MIOFILE&, GLOBAL_PREFS_MASK&); void write_day_prefs(MIOFILE&); inline double cpu_scheduling_period() { return cpu_scheduling_period_minutes*60; } static double parse_mod_time(const char*); bool get_need_idle_state(bool have_gpu) { // is any pref set that causes different behavior if user is active? // if (!run_if_user_active) return true; if (have_gpu && !run_gpu_if_user_active) return true; if (suspend_if_no_recent_input) return true; if (niu_cpu_usage_limit && niu_cpu_usage_limit != cpu_usage_limit) return true; if (niu_max_ncpus_pct && niu_max_ncpus_pct != max_ncpus_pct) return true; if (niu_suspend_cpu_usage && niu_suspend_cpu_usage != suspend_cpu_usage) return true; if (ram_max_used_busy_frac != ram_max_used_idle_frac) return true; return false; } }; #endif