parent
							
								
									59ea017b94
								
							
						
					
					
						commit
						b156613b2f
					
				
				 4 changed files with 90 additions and 73 deletions
			
			
		| @ -0,0 +1,21 @@ | ||||
| #pragma once | ||||
| 
 | ||||
| #include <cstdlib> | ||||
| #include <fstream> | ||||
| 
 | ||||
| 
 | ||||
| // no-op base hw class
 | ||||
| class HardwareNone { | ||||
| public: | ||||
|   static constexpr float MAX_VOLUME = 0; | ||||
|   static constexpr float MIN_VOLUME = 0; | ||||
| 
 | ||||
|   static std::string get_os_version() { return "openpilot for PC"; }; | ||||
| 
 | ||||
|   static void reboot() {}; | ||||
|   static void poweroff() {}; | ||||
|   static void set_brightness(int percent) {}; | ||||
| 
 | ||||
|   static bool get_ssh_enabled() { return false; }; | ||||
|   static void set_ssh_enabled(bool enabled) {}; | ||||
| }; | ||||
| @ -0,0 +1,35 @@ | ||||
| #pragma once | ||||
| 
 | ||||
| #include <cstdlib> | ||||
| #include <fstream> | ||||
| 
 | ||||
| #include "selfdrive/common/util.h" | ||||
| #include "selfdrive/hardware/base.h" | ||||
| 
 | ||||
| class HardwareEon : public HardwareNone { | ||||
| public: | ||||
|   static constexpr float MAX_VOLUME = 1.0; | ||||
|   static constexpr float MIN_VOLUME = 0.5; | ||||
| 
 | ||||
|   static std::string get_os_version() { | ||||
|     return "NEOS " + util::read_file("/VERSION"); | ||||
|   }; | ||||
| 
 | ||||
|   static void reboot() { std::system("reboot"); }; | ||||
|   static void poweroff() { std::system("LD_LIBRARY_PATH= svc power shutdown"); }; | ||||
|   static void set_brightness(int percent) { | ||||
|     std::ofstream brightness_control("/sys/class/leds/lcd-backlight/brightness"); | ||||
|     if (brightness_control.is_open()) { | ||||
|       brightness_control << (int)(percent * (255/100.)) << "\n"; | ||||
|       brightness_control.close(); | ||||
|     } | ||||
|   }; | ||||
| 
 | ||||
|   static bool get_ssh_enabled() { | ||||
|     return std::system("getprop persist.neos.ssh | grep -qF '1'") == 0; | ||||
|   }; | ||||
|   static void set_ssh_enabled(bool enabled) { | ||||
|     std::string cmd = util::string_format("setprop persist.neos.ssh %d", enabled ? 1 : 0); | ||||
|     std::system(cmd.c_str()); | ||||
|   }; | ||||
| }; | ||||
| @ -0,0 +1,32 @@ | ||||
| #pragma once | ||||
| 
 | ||||
| #include <cstdlib> | ||||
| #include <fstream> | ||||
| 
 | ||||
| #include "selfdrive/common/util.h" | ||||
| #include "selfdrive/common/params.h" | ||||
| #include "selfdrive/hardware/base.h" | ||||
| 
 | ||||
| class HardwareTici : public HardwareNone { | ||||
| public: | ||||
|   static constexpr float MAX_VOLUME = 0.5; | ||||
|   static constexpr float MIN_VOLUME = 0.4; | ||||
| 
 | ||||
|   static std::string get_os_version() { | ||||
|     return "AGNOS " + util::read_file("/VERSION"); | ||||
|   }; | ||||
| 
 | ||||
|   static void reboot() { std::system("sudo reboot"); }; | ||||
|   static void poweroff() { std::system("sudo poweroff"); }; | ||||
|   static void set_brightness(int percent) { | ||||
|     std::ofstream brightness_control("/sys/class/backlight/panel0-backlight/brightness"); | ||||
|     if (brightness_control.is_open()) { | ||||
|       brightness_control << (percent * (int)(1023/100.)) << "\n"; | ||||
|       brightness_control.close(); | ||||
|     } | ||||
|   }; | ||||
|   static void set_display_power(bool on) {}; | ||||
| 
 | ||||
|   static bool get_ssh_enabled() { return Params().read_db_bool("SshEnabled"); }; | ||||
|   static void set_ssh_enabled(bool enabled) { Params().write_db_value("SshEnabled", (enabled ? "1" : "0")); }; | ||||
| }; | ||||
					Loading…
					
					
				
		Reference in new issue