| #include <string.h> |
| |
| #include <arm/api.h> |
| #include <arm/linux/api.h> |
| #include <arm/android/api.h> |
| |
| |
| void cpuinfo_arm_android_parse_chipset_properties( |
| const char proc_cpuinfo_hardware[CPUINFO_HARDWARE_VALUE_MAX], |
| const char ro_product_board[CPUINFO_BUILD_PROP_VALUE_MAX], |
| const char ro_board_platform[CPUINFO_BUILD_PROP_VALUE_MAX], |
| const char ro_mediatek_platform[CPUINFO_BUILD_PROP_VALUE_MAX], |
| const char ro_arch[CPUINFO_BUILD_PROP_VALUE_MAX], |
| const char ro_chipname[CPUINFO_BUILD_PROP_VALUE_MAX], |
| uint32_t cores, |
| uint32_t max_cpu_freq_max, |
| char chipset_name[CPUINFO_ARM_CHIPSET_NAME_MAX]) |
| { |
| struct cpuinfo_android_properties properties; |
| strncpy(properties.proc_cpuinfo_hardware, proc_cpuinfo_hardware, CPUINFO_HARDWARE_VALUE_MAX); |
| strncpy(properties.ro_product_board, ro_product_board, CPUINFO_BUILD_PROP_VALUE_MAX); |
| strncpy(properties.ro_board_platform, ro_board_platform, CPUINFO_BUILD_PROP_VALUE_MAX); |
| strncpy(properties.ro_mediatek_platform, ro_mediatek_platform, CPUINFO_BUILD_PROP_VALUE_MAX); |
| strncpy(properties.ro_arch, ro_arch, CPUINFO_BUILD_PROP_VALUE_MAX); |
| strncpy(properties.ro_chipname, ro_chipname, CPUINFO_BUILD_PROP_VALUE_MAX); |
| |
| struct cpuinfo_arm_chipset chipset = |
| cpuinfo_arm_android_decode_chipset(&properties, cores, max_cpu_freq_max); |
| if (chipset.series == cpuinfo_arm_chipset_series_unknown) { |
| chipset_name[0] = 0; |
| } else { |
| cpuinfo_arm_chipset_to_string(&chipset, chipset_name); |
| } |
| } |
| |
| void cpuinfo_arm_android_parse_proc_cpuinfo_hardware( |
| const char hardware[CPUINFO_HARDWARE_VALUE_MAX], uint32_t cores, uint32_t max_cpu_freq_max, bool is_tegra, |
| char chipset_name[CPUINFO_ARM_CHIPSET_NAME_MAX]) |
| { |
| struct cpuinfo_arm_chipset chipset = |
| cpuinfo_arm_linux_decode_chipset_from_proc_cpuinfo_hardware(hardware, cores, max_cpu_freq_max, is_tegra); |
| if (chipset.series == cpuinfo_arm_chipset_series_unknown) { |
| chipset_name[0] = 0; |
| } else { |
| cpuinfo_arm_fixup_chipset(&chipset, cores, max_cpu_freq_max); |
| cpuinfo_arm_chipset_to_string(&chipset, chipset_name); |
| } |
| } |
| |
| void cpuinfo_arm_android_parse_ro_product_board( |
| const char board[CPUINFO_BUILD_PROP_VALUE_MAX], uint32_t cores, uint32_t max_cpu_freq_max, |
| char chipset_name[CPUINFO_ARM_CHIPSET_NAME_MAX]) |
| { |
| struct cpuinfo_arm_chipset chipset = |
| cpuinfo_arm_android_decode_chipset_from_ro_product_board(board, cores, max_cpu_freq_max); |
| if (chipset.series == cpuinfo_arm_chipset_series_unknown) { |
| chipset_name[0] = 0; |
| } else { |
| cpuinfo_arm_fixup_chipset(&chipset, cores, max_cpu_freq_max); |
| cpuinfo_arm_chipset_to_string(&chipset, chipset_name); |
| } |
| } |
| |
| void cpuinfo_arm_android_parse_ro_board_platform( |
| const char platform[CPUINFO_BUILD_PROP_VALUE_MAX], uint32_t cores, uint32_t max_cpu_freq_max, |
| char chipset_name[CPUINFO_ARM_CHIPSET_NAME_MAX]) |
| { |
| struct cpuinfo_arm_chipset chipset = |
| cpuinfo_arm_android_decode_chipset_from_ro_board_platform(platform, cores, max_cpu_freq_max); |
| if (chipset.series == cpuinfo_arm_chipset_series_unknown) { |
| chipset_name[0] = 0; |
| } else { |
| cpuinfo_arm_fixup_chipset(&chipset, cores, max_cpu_freq_max); |
| cpuinfo_arm_chipset_to_string(&chipset, chipset_name); |
| } |
| } |
| |
| void cpuinfo_arm_android_parse_ro_mediatek_platform( |
| const char platform[CPUINFO_BUILD_PROP_VALUE_MAX], uint32_t cores, uint32_t max_cpu_freq_max, |
| char chipset_name[CPUINFO_ARM_CHIPSET_NAME_MAX]) |
| { |
| struct cpuinfo_arm_chipset chipset = cpuinfo_arm_android_decode_chipset_from_ro_mediatek_platform(platform); |
| if (chipset.series == cpuinfo_arm_chipset_series_unknown) { |
| chipset_name[0] = 0; |
| } else { |
| cpuinfo_arm_fixup_chipset(&chipset, cores, max_cpu_freq_max); |
| cpuinfo_arm_chipset_to_string(&chipset, chipset_name); |
| } |
| } |
| |
| void cpuinfo_arm_android_parse_ro_arch( |
| const char arch[CPUINFO_BUILD_PROP_VALUE_MAX], uint32_t cores, uint32_t max_cpu_freq_max, |
| char chipset_name[CPUINFO_ARM_CHIPSET_NAME_MAX]) |
| { |
| struct cpuinfo_arm_chipset chipset = cpuinfo_arm_android_decode_chipset_from_ro_arch(arch); |
| if (chipset.series == cpuinfo_arm_chipset_series_unknown) { |
| chipset_name[0] = 0; |
| } else { |
| cpuinfo_arm_fixup_chipset(&chipset, cores, max_cpu_freq_max); |
| cpuinfo_arm_chipset_to_string(&chipset, chipset_name); |
| } |
| } |
| |
| void cpuinfo_arm_android_parse_ro_chipname( |
| const char chipname[CPUINFO_BUILD_PROP_VALUE_MAX], uint32_t cores, uint32_t max_cpu_freq_max, |
| char chipset_name[CPUINFO_ARM_CHIPSET_NAME_MAX]) |
| { |
| struct cpuinfo_arm_chipset chipset = cpuinfo_arm_android_decode_chipset_from_ro_chipname(chipname); |
| if (chipset.series == cpuinfo_arm_chipset_series_unknown) { |
| chipset_name[0] = 0; |
| } else { |
| cpuinfo_arm_fixup_chipset(&chipset, cores, max_cpu_freq_max); |
| cpuinfo_arm_chipset_to_string(&chipset, chipset_name); |
| } |
| } |