2004-04-22 02:57:39 +04:00
|
|
|
/*
|
2008-03-15 19:59:30 +03:00
|
|
|
* Copyright (c) 2004-2008, Haiku, Inc.
|
2006-03-06 16:40:36 +03:00
|
|
|
* Distributed under the terms of the MIT license.
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Stefano Ceccherini
|
|
|
|
* Axel Dörfler, axeld@pinc-software.de
|
2004-12-01 00:11:37 +03:00
|
|
|
*/
|
2004-04-22 02:57:39 +04:00
|
|
|
|
|
|
|
|
2008-09-17 20:27:17 +04:00
|
|
|
#include <ksystem_info.h>
|
2007-09-27 16:21:33 +04:00
|
|
|
#include <system_info.h>
|
2008-03-15 19:59:30 +03:00
|
|
|
#include <arch/system_info.h>
|
|
|
|
|
|
|
|
#include <string.h>
|
2007-09-27 16:21:33 +04:00
|
|
|
|
2004-04-22 02:57:39 +04:00
|
|
|
#include <OS.h>
|
|
|
|
#include <KernelExport.h>
|
|
|
|
|
2008-09-17 20:27:17 +04:00
|
|
|
#include <block_cache.h>
|
2006-02-01 23:03:55 +03:00
|
|
|
#include <cpu.h>
|
2004-04-22 02:57:39 +04:00
|
|
|
#include <debug.h>
|
2007-09-27 16:21:33 +04:00
|
|
|
#include <kernel.h>
|
2004-04-22 02:57:39 +04:00
|
|
|
#include <port.h>
|
|
|
|
#include <real_time_clock.h>
|
|
|
|
#include <sem.h>
|
|
|
|
#include <smp.h>
|
2004-12-01 00:11:37 +03:00
|
|
|
#include <team.h>
|
|
|
|
#include <thread.h>
|
2006-02-01 23:03:55 +03:00
|
|
|
#include <vm.h>
|
2004-12-01 00:11:37 +03:00
|
|
|
#include <vm_page.h>
|
2004-04-22 02:57:39 +04:00
|
|
|
|
|
|
|
|
|
|
|
const static int64 kKernelVersion = 0x1;
|
2006-03-06 16:40:36 +03:00
|
|
|
const static char *kKernelName = "kernel_" HAIKU_ARCH;
|
|
|
|
|
|
|
|
|
2007-05-19 19:36:32 +04:00
|
|
|
// Haiku SVN revision. Will be set when copying the kernel to the image.
|
|
|
|
// Lives in a separate section so that it can easily be found.
|
|
|
|
static uint32 sHaikuRevision __attribute__((section("_haiku_revision")));
|
|
|
|
|
|
|
|
|
2006-03-06 16:40:36 +03:00
|
|
|
static int
|
|
|
|
dump_info(int argc, char **argv)
|
|
|
|
{
|
2008-10-16 01:24:32 +04:00
|
|
|
kprintf("kernel build: %s %s\n", __DATE__, __TIME__);
|
|
|
|
kprintf("SVN revision: %lu\n\n", sHaikuRevision);
|
|
|
|
|
2006-03-06 16:40:36 +03:00
|
|
|
kprintf("cpu count: %ld, active times:\n", smp_get_num_cpus());
|
|
|
|
|
2008-03-15 19:59:30 +03:00
|
|
|
for (int32 i = 0; i < smp_get_num_cpus(); i++)
|
2006-03-06 16:40:36 +03:00
|
|
|
kprintf(" [%ld] %Ld\n", i + 1, cpu_get_active_time(i));
|
|
|
|
|
|
|
|
// ToDo: Add page_faults
|
|
|
|
kprintf("pages:\t\t%ld (%ld max)\n", vm_page_num_pages() - vm_page_num_free_pages(),
|
|
|
|
vm_page_num_pages());
|
|
|
|
|
|
|
|
kprintf("sems:\t\t%ld (%ld max)\n", sem_used_sems(), sem_max_sems());
|
|
|
|
kprintf("ports:\t\t%ld (%ld max)\n", port_used_ports(), port_max_ports());
|
|
|
|
kprintf("threads:\t%ld (%ld max)\n", thread_used_threads(), thread_max_threads());
|
|
|
|
kprintf("teams:\t\t%ld (%ld max)\n", team_used_teams(), team_max_teams());
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// #pragma mark -
|
2004-04-22 02:57:39 +04:00
|
|
|
|
|
|
|
|
|
|
|
status_t
|
|
|
|
_get_system_info(system_info *info, size_t size)
|
|
|
|
{
|
|
|
|
if (size != sizeof(system_info))
|
|
|
|
return B_BAD_VALUE;
|
|
|
|
|
|
|
|
memset(info, 0, sizeof(system_info));
|
|
|
|
|
2004-11-29 02:13:22 +03:00
|
|
|
info->boot_time = rtc_boot_time();
|
2004-04-22 02:57:39 +04:00
|
|
|
info->cpu_count = smp_get_num_cpus();
|
2004-12-01 00:11:37 +03:00
|
|
|
|
2008-03-15 19:59:30 +03:00
|
|
|
for (int32 i = 0; i < info->cpu_count; i++)
|
2006-02-01 23:03:55 +03:00
|
|
|
info->cpu_infos[i].active_time = cpu_get_active_time(i);
|
2005-07-01 04:31:38 +04:00
|
|
|
|
2008-08-06 04:28:28 +04:00
|
|
|
vm_page_get_stats(info);
|
2008-04-02 16:47:08 +04:00
|
|
|
// TODO: Add page_faults
|
|
|
|
|
2004-12-01 00:11:37 +03:00
|
|
|
info->used_threads = thread_used_threads();
|
|
|
|
info->max_threads = thread_max_threads();
|
|
|
|
info->used_teams = team_used_teams();
|
|
|
|
info->max_teams = team_max_teams();
|
2004-04-22 02:57:39 +04:00
|
|
|
info->used_ports = port_used_ports();
|
|
|
|
info->max_ports = port_max_ports();
|
|
|
|
info->used_sems = sem_used_sems();
|
|
|
|
info->max_sems = sem_max_sems();
|
|
|
|
|
|
|
|
info->kernel_version = kKernelVersion;
|
|
|
|
strlcpy(info->kernel_name, kKernelName, B_FILE_NAME_LENGTH);
|
|
|
|
strlcpy(info->kernel_build_date, __DATE__, B_OS_NAME_LENGTH);
|
|
|
|
strlcpy(info->kernel_build_time, __TIME__, B_OS_NAME_LENGTH);
|
|
|
|
|
2004-12-01 00:11:37 +03:00
|
|
|
// all other stuff is architecture specific
|
|
|
|
return arch_get_system_info(info, size);
|
|
|
|
}
|
|
|
|
|
2004-04-22 02:57:39 +04:00
|
|
|
|
2008-04-02 16:47:08 +04:00
|
|
|
status_t
|
2004-12-01 00:11:37 +03:00
|
|
|
system_info_init(struct kernel_args *args)
|
|
|
|
{
|
2006-03-06 16:40:36 +03:00
|
|
|
add_debugger_command("info", &dump_info, "System info");
|
|
|
|
|
2004-12-01 00:11:37 +03:00
|
|
|
return arch_system_info_init(args);
|
2004-04-22 02:57:39 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-05-19 19:36:32 +04:00
|
|
|
uint32
|
|
|
|
get_haiku_revision(void)
|
|
|
|
{
|
|
|
|
return sHaikuRevision;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2004-12-01 00:11:37 +03:00
|
|
|
// #pragma mark -
|
|
|
|
|
|
|
|
|
2004-04-22 02:57:39 +04:00
|
|
|
status_t
|
|
|
|
_user_get_system_info(system_info *userInfo, size_t size)
|
|
|
|
{
|
|
|
|
// The BeBook says get_system_info() always returns B_OK,
|
|
|
|
// but that ain't true with invalid addresses
|
|
|
|
if (userInfo == NULL || !IS_USER_ADDRESS(userInfo))
|
|
|
|
return B_BAD_ADDRESS;
|
|
|
|
|
2008-03-15 19:59:30 +03:00
|
|
|
system_info info;
|
|
|
|
status_t status = _get_system_info(&info, size);
|
2004-04-22 02:57:39 +04:00
|
|
|
if (status == B_OK) {
|
|
|
|
if (user_memcpy(userInfo, &info, sizeof(system_info)) < B_OK)
|
|
|
|
return B_BAD_ADDRESS;
|
|
|
|
|
|
|
|
return B_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
return status;
|
|
|
|
}
|
2008-09-17 20:27:17 +04:00
|
|
|
|
|
|
|
|
|
|
|
status_t
|
|
|
|
_user_get_system_info_etc(int32 id, void* userInfo, size_t size)
|
|
|
|
{
|
|
|
|
if (userInfo == NULL || !IS_USER_ADDRESS(userInfo))
|
|
|
|
return B_BAD_ADDRESS;
|
|
|
|
|
|
|
|
switch (id) {
|
|
|
|
case B_MEMORY_INFO:
|
|
|
|
{
|
|
|
|
if (size < sizeof(system_memory_info))
|
|
|
|
return B_BAD_VALUE;
|
|
|
|
|
|
|
|
system_memory_info info;
|
|
|
|
vm_get_info(&info);
|
|
|
|
|
|
|
|
info.block_cache_memory = block_cache_used_memory();
|
|
|
|
|
|
|
|
return user_memcpy(userInfo, &info, sizeof(system_memory_info));
|
|
|
|
}
|
|
|
|
|
|
|
|
default:
|
|
|
|
return B_BAD_VALUE;
|
|
|
|
}
|
|
|
|
}
|