summaryrefslogtreecommitdiffstats
path: root/src/power/LMI_PowerManagementCapabilitiesProvider.c
diff options
context:
space:
mode:
authorRadek Novacek <rnovacek@redhat.com>2012-08-27 15:01:46 +0200
committerRadek Novacek <rnovacek@redhat.com>2012-08-28 14:37:33 +0200
commit4721a6cb186e7d6908ff1f361d0bc81e182473ad (patch)
treed63f8e7b8db9bdbfca8b6c85d21642ad237fc6eb /src/power/LMI_PowerManagementCapabilitiesProvider.c
parent3333004967971ad1720b74da4ce09949f023852e (diff)
downloadopenlmi-providers-4721a6cb186e7d6908ff1f361d0bc81e182473ad.tar.gz
openlmi-providers-4721a6cb186e7d6908ff1f361d0bc81e182473ad.tar.xz
openlmi-providers-4721a6cb186e7d6908ff1f361d0bc81e182473ad.zip
Rename prefix from Cura_ to LMI_
Diffstat (limited to 'src/power/LMI_PowerManagementCapabilitiesProvider.c')
-rw-r--r--src/power/LMI_PowerManagementCapabilitiesProvider.c179
1 files changed, 179 insertions, 0 deletions
diff --git a/src/power/LMI_PowerManagementCapabilitiesProvider.c b/src/power/LMI_PowerManagementCapabilitiesProvider.c
new file mode 100644
index 0000000..d97c144
--- /dev/null
+++ b/src/power/LMI_PowerManagementCapabilitiesProvider.c
@@ -0,0 +1,179 @@
+/*
+ * Copyright (C) 2012 Radek Novacek <rnovacek@redhat.com>
+ *
+ * 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; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <konkret/konkret.h>
+#include "LMI_PowerManagementCapabilities.h"
+
+#include "power.h"
+
+static const CMPIBroker* _cb = NULL;
+
+static void LMI_PowerManagementCapabilitiesInitialize(CMPIInstanceMI *mi)
+{
+ mi->hdl = power_ref(_cb);
+}
+
+static void LMI_PowerManagementCapabilitiesInitializeMethod(CMPIMethodMI *mi)
+{
+ mi->hdl = power_ref(_cb);
+}
+
+static CMPIStatus LMI_PowerManagementCapabilitiesCleanup(
+ CMPIInstanceMI* mi,
+ const CMPIContext* cc,
+ CMPIBoolean term)
+{
+ power_unref(mi->hdl);
+ mi->hdl = NULL;
+ CMReturn(CMPI_RC_OK);
+}
+
+static CMPIStatus LMI_PowerManagementCapabilitiesEnumInstanceNames(
+ CMPIInstanceMI* mi,
+ const CMPIContext* cc,
+ const CMPIResult* cr,
+ const CMPIObjectPath* cop)
+{
+ return KDefaultEnumerateInstanceNames(
+ _cb, mi, cc, cr, cop);
+}
+
+static CMPIStatus LMI_PowerManagementCapabilitiesEnumInstances(
+ CMPIInstanceMI* mi,
+ const CMPIContext* cc,
+ const CMPIResult* cr,
+ const CMPIObjectPath* cop,
+ const char** properties)
+{
+ const char *ns = KNameSpace(cop);
+
+ LMI_PowerManagementCapabilities w;
+ LMI_PowerManagementCapabilities_Init(&w, _cb, ns);
+ // TODO: make it unique
+ LMI_PowerManagementCapabilities_Set_InstanceID(&w, "Linux:PowerManagementCapabilities");
+ LMI_PowerManagementCapabilities_Set_ElementName(&w, "Linux:PowerManagementCapabilities");
+ LMI_PowerManagementCapabilities_Set_Caption(&w, "Linux:PowerManagementCapabilities");
+
+ int count;
+ unsigned short *list = power_available_requested_power_states(mi->hdl, &count);
+ LMI_PowerManagementCapabilities_Init_PowerStatesSupported(&w, count);
+ for (int i = 0; i < count; i++) {
+ LMI_PowerManagementCapabilities_Set_PowerStatesSupported(&w, i, list[i]);
+ }
+
+ // TODO: get this list dynamically from PowerStatesSupported (see SMASH)
+ LMI_PowerManagementCapabilities_Init_PowerChangeCapabilities(&w, 3);
+ LMI_PowerManagementCapabilities_Set_PowerChangeCapabilities(&w, 0, LMI_PowerManagementCapabilities_PowerChangeCapabilities_Power_State_Settable);
+ LMI_PowerManagementCapabilities_Set_PowerChangeCapabilities(&w, 1, LMI_PowerManagementCapabilities_PowerChangeCapabilities_Power_Cycling_Supported);
+ LMI_PowerManagementCapabilities_Set_PowerChangeCapabilities(&w, 2, LMI_PowerManagementCapabilities_PowerChangeCapabilities_Graceful_Shutdown_Supported);
+ KReturnInstance(cr, w);
+ CMReturn(CMPI_RC_OK);
+}
+
+static CMPIStatus LMI_PowerManagementCapabilitiesGetInstance(
+ CMPIInstanceMI* mi,
+ const CMPIContext* cc,
+ const CMPIResult* cr,
+ const CMPIObjectPath* cop,
+ const char** properties)
+{
+ return KDefaultGetInstance(
+ _cb, mi, cc, cr, cop, properties);
+}
+
+static CMPIStatus LMI_PowerManagementCapabilitiesCreateInstance(
+ CMPIInstanceMI* mi,
+ const CMPIContext* cc,
+ const CMPIResult* cr,
+ const CMPIObjectPath* cop,
+ const CMPIInstance* ci)
+{
+ CMReturn(CMPI_RC_ERR_NOT_SUPPORTED);
+}
+
+static CMPIStatus LMI_PowerManagementCapabilitiesModifyInstance(
+ CMPIInstanceMI* mi,
+ const CMPIContext* cc,
+ const CMPIResult* cr,
+ const CMPIObjectPath* cop,
+ const CMPIInstance* ci,
+ const char** properties)
+{
+ CMReturn(CMPI_RC_ERR_NOT_SUPPORTED);
+}
+
+static CMPIStatus LMI_PowerManagementCapabilitiesDeleteInstance(
+ CMPIInstanceMI* mi,
+ const CMPIContext* cc,
+ const CMPIResult* cr,
+ const CMPIObjectPath* cop)
+{
+ CMReturn(CMPI_RC_ERR_NOT_SUPPORTED);
+}
+
+static CMPIStatus LMI_PowerManagementCapabilitiesExecQuery(
+ CMPIInstanceMI* mi,
+ const CMPIContext* cc,
+ const CMPIResult* cr,
+ const CMPIObjectPath* cop,
+ const char* lang,
+ const char* query)
+{
+ CMReturn(CMPI_RC_ERR_NOT_SUPPORTED);
+}
+
+CMInstanceMIStub(
+ LMI_PowerManagementCapabilities,
+ LMI_PowerManagementCapabilities,
+ _cb,
+ LMI_PowerManagementCapabilitiesInitialize(&mi))
+
+static CMPIStatus LMI_PowerManagementCapabilitiesMethodCleanup(
+ CMPIMethodMI* mi,
+ const CMPIContext* cc,
+ CMPIBoolean term)
+{
+ power_unref(mi->hdl);
+ mi->hdl = NULL;
+
+ CMReturn(CMPI_RC_OK);
+}
+
+static CMPIStatus LMI_PowerManagementCapabilitiesInvokeMethod(
+ CMPIMethodMI* mi,
+ const CMPIContext* cc,
+ const CMPIResult* cr,
+ const CMPIObjectPath* cop,
+ const char* meth,
+ const CMPIArgs* in,
+ CMPIArgs* out)
+{
+ return LMI_PowerManagementCapabilities_DispatchMethod(
+ _cb, mi, cc, cr, cop, meth, in, out);
+}
+
+CMMethodMIStub(
+ LMI_PowerManagementCapabilities,
+ LMI_PowerManagementCapabilities,
+ _cb,
+ LMI_PowerManagementCapabilitiesInitializeMethod(&mi))
+
+KONKRET_REGISTRATION(
+ "root/cimv2",
+ "LMI_PowerManagementCapabilities",
+ "LMI_PowerManagementCapabilities",
+ "instance method")