Solaris subagent: implemented System.Memory.Physical.* parameters
[public/netxms.git] / src / agent / subagents / sunos / main.cpp
index cb41ce2..d04c870 100644 (file)
 //
 
 LONG H_CPUCount(char *pszParam, char *pArg, char *pValue);
+LONG H_CPUUsage(char *pszParam, char *pArg, char *pValue);
 LONG H_DiskInfo(char *pszParam, char *pArg, char *pValue);
 LONG H_Hostname(char *pszParam, char *pArg, char *pValue);
 LONG H_KStat(char *pszParam, char *pArg, char *pValue);
 LONG H_LoadAvg(char *pszParam, char *pArg, char *pValue);
+LONG H_MemoryInfo(char *pszParam, char *pArg, char *pValue);
 LONG H_NetIfList(char *pszParam, char *pArg, NETXMS_VALUES_LIST *pValue);
 LONG H_NetIfAdminStatus(char *pszParam, char *pArg, char *pValue);
 LONG H_NetIfDescription(char *pszParam, char *pArg, char *pValue);
@@ -44,11 +46,25 @@ LONG H_Uname(char *pszParam, char *pArg, char *pValue);
 LONG H_Uptime(char *pszParam, char *pArg, char *pValue);
 
 
+//
+// Global variables
+//
+
+BOOL g_bShutdown = FALSE;
+
+
+//
+// Static data
+//
+
+static THREAD m_hCPUStatThread = INVALID_THREAD_HANDLE;
+
+
 //
 // Detect support for source packages
 //
 
-LONG H_SourcePkg(char *pszParam, char *pArg, char *pValue)
+static LONG H_SourcePkg(char *pszParam, char *pArg, char *pValue)
 {
        ret_int(pValue, 1);
        return SYSINFO_RC_SUCCESS;
@@ -61,6 +77,8 @@ LONG H_SourcePkg(char *pszParam, char *pArg, char *pValue)
 
 static void UnloadHandler(void)
 {
+       g_bShutdown = TRUE;
+       ThreadJoin(m_hCPUStatThread);
 }
 
 
@@ -92,8 +110,20 @@ static NETXMS_SUBAGENT_PARAM m_parameters[] =
    { "System.CPU.LoadAvg", H_LoadAvg, (char *)0, DCI_DT_FLOAT, "Average CPU load for last minute" },
    { "System.CPU.LoadAvg5", H_LoadAvg, (char *)1, DCI_DT_FLOAT, "Average CPU load for last 5 minutes" },
    { "System.CPU.LoadAvg15", H_LoadAvg, (char *)2, DCI_DT_FLOAT, "Average CPU load for last 15 minutes" },
+   { "System.CPU.Usage", H_CPUUsage, "T0", DCI_DT_FLOAT, "Average CPU(s) utilization for last minute" },
+   { "System.CPU.Usage5", H_CPUUsage, "T1", DCI_DT_FLOAT, "Average CPU(s) utilization for last 5 minutes" },
+   { "System.CPU.Usage15", H_CPUUsage, "T2", DCI_DT_FLOAT, "Average CPU(s) utilization for last 15 minutes" },
+   { "System.CPU.Usage(*)", H_CPUUsage, "C0", DCI_DT_FLOAT, "Average CPU {instance} utilization for last minute" },
+   { "System.CPU.Usage5(*)", H_CPUUsage, "C1", DCI_DT_FLOAT, "Average CPU {instance} utilization for last 5 minutes" },
+   { "System.CPU.Usage15(*)", H_CPUUsage, "C2", DCI_DT_FLOAT, "Average CPU {instance} utilization for last 15 minutes" },
    { "System.Hostname", H_Hostname, NULL, DCI_DT_STRING, "Host name" },
    { "System.KStat(*)", H_KStat, NULL, DCI_DT_STRING, "" },
+       { "System.Memory.Physical.Free", H_MemoryInfo, (char *)MEMINFO_PHYSICAL_FREE, DCI_DT_UINT64, "Available physical memory" },
+       { "System.Memory.Physical.Total", H_MemoryInfo, (char *)MEMINFO_PHYSICAL_TOTAL, DCI_DT_UINT64, "Total amount of physical memory" },
+       { "System.Memory.Physical.Used", H_MemoryInfo, (char *)MEMINFO_PHYSICAL_USED, DCI_DT_UINT64, "Used physical memory" },
+   { "System.Memory.Swap.Free", H_MemoryInfo, (char *)MEMINFO_SWAP_FREE, DCI_DT_UINT64, "Free swap space" },
+   { "System.Memory.Swap.Total", H_MemoryInfo, (char *)MEMINFO_SWAP_TOTAL, DCI_DT_UINT64, "Total amount of swap space" },
+   { "System.Memory.Swap.Used", H_MemoryInfo, (char *)MEMINFO_SWAP_USED, DCI_DT_UINT64, "Used swap space" },
    { "System.ProcessCount", H_SysProcCount, NULL, DCI_DT_INT, "Total number of processes" },
    { "System.Uname", H_Uname, NULL, DCI_DT_STRING, "System uname" },
    { "System.Uptime", H_Uptime, NULL, DCI_DT_UINT, "System uptime" }
@@ -122,6 +152,8 @@ static NETXMS_SUBAGENT_INFO m_info =
 
 extern "C" BOOL NxSubAgentInit(NETXMS_SUBAGENT_INFO **ppInfo, TCHAR *pszConfigFile)
 {
+       m_hCPUStatThread = ThreadCreateEx(CPUStatCollector, 0, NULL);
+
    *ppInfo = &m_info;
    return TRUE;
 }