diff options
author | entityfx <artem.solopiy@gmail.com> | 2020-06-13 21:58:04 +0300 |
---|---|---|
committer | Leandro A. F. Pereira <leandro@hardinfo.org> | 2020-06-14 15:14:23 -0700 |
commit | c57025a71ba0147369a5499ed35e395429de40e7 (patch) | |
tree | 1574c71235790a11e56d8aed03aaad94385c1f59 /includes | |
parent | 6f177bed0cb3e0b4d862355f8280c55313ac825d (diff) |
E2K: added initial support of MCST Elbrus 2000 CPU architecture
E2K (Elbrus 2000) - this is VLIW/EPIC architecture, like Intel Itanium (IA-64) architecture.
Ref: https://en.wikipedia.org/wiki/Elbrus_2000
Diffstat (limited to 'includes')
-rw-r--r-- | includes/e2k/processor-platform.h | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/includes/e2k/processor-platform.h b/includes/e2k/processor-platform.h new file mode 100644 index 00000000..a252485f --- /dev/null +++ b/includes/e2k/processor-platform.h @@ -0,0 +1,74 @@ +/* + * HardInfo - Displays System Information + * Copyright (C) 2003-2006 Leandro A. F. Pereira <leandro@hardinfo.org> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, version 2. + * + * This program 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#ifndef __PROCESSOR_PLATFORM_H__ +#define __PROCESSOR_PLATFORM_H__ + +#include "cpu_util.h" + +/* + +E2K /proc/cpuinfo: + + +processor : 0 +vendor_id : E8C-SWTX +cpu family : 4 +model : 7 +model name : E8C +revision : 2 +cpu MHz : 1299.912740 +cache0 : level=1 type=Instruction scope=Private size=128K line_size=256 associativity=4 +cache1 : level=1 type=Data scope=Private size=64K line_size=32 associativity=4 +cache2 : level=2 type=Unified scope=Private size=512K line_size=64 associativity=4 +cache3 : level=3 type=Unified scope=Private size=16384K line_size=64 associativity=16 +bogomips : 2600.68 + +*/ + + +typedef struct _ProcessorCache ProcessorCache; + +struct _ProcessorCache { + gint level; + gint number_of_sets; + gint physical_line_partition; + gint size; + gchar *type; + gint ways_of_associativity; + gint uid; /* uid is unique among caches with the same (type, level) */ + gchar *shared_cpu_list; /* some kernel's don't give a uid, so try shared_cpu_list */ + gint phy_sock; +}; + + + +//e2k processor structure +struct _Processor { + gint id; + gfloat cpu_mhz; + gchar *model_name; + gchar *vendor_id; + gfloat bogomips; + + gint model, family, revision; + + GSList *cache; +}; + +#endif /* __PROCESSOR_PLATFORM_H__ */ |