#include "dmidecodemodule.h" static PyObject* dmidecode_get(PyObject *self, char* section) { bzero(buffer, 50000); PyObject *list = PyList_New(0); char *argv[4]; argv[0] = "dmidecode"; argv[1] = "--type"; argv[2] = section; argv[3] = NULL; submain(3, argv); PyList_Append(list, PyUnicode_Splitlines(Py_BuildValue("s", buffer), 1)); return list; } static PyObject* dmidecode_get_bios(PyObject *self, PyObject *args) { return dmidecode_get(self, "bios"); } static PyObject* dmidecode_get_system(PyObject *self, PyObject *args) { return dmidecode_get(self, "system"); } static PyObject* dmidecode_get_baseboard(PyObject *self, PyObject *args) { return dmidecode_get(self, "baseboard"); } static PyObject* dmidecode_get_chassis(PyObject *self, PyObject *args) { return dmidecode_get(self, "chassis"); } static PyObject* dmidecode_get_processor(PyObject *self, PyObject *args) { return dmidecode_get(self, "processor"); } static PyObject* dmidecode_get_memory(PyObject *self, PyObject *args) { return dmidecode_get(self, "memory"); } static PyObject* dmidecode_get_cache(PyObject *self, PyObject *args) { return dmidecode_get(self, "cache"); } static PyObject* dmidecode_get_connector(PyObject *self, PyObject *args) { return dmidecode_get(self, "connector"); } static PyObject* dmidecode_get_slot(PyObject *self, PyObject *args) { return dmidecode_get(self, "slot"); } PyMethodDef DMIDataMethods[] = { { "bios", dmidecode_get_bios, METH_VARARGS, "BIOS Data" }, { "system", dmidecode_get_system, METH_VARARGS, "System Data" }, { "baseboard", dmidecode_get_baseboard, METH_VARARGS, "Baseboard Data" }, { "chassis", dmidecode_get_chassis, METH_VARARGS, "Chassis Data" }, { "processor", dmidecode_get_processor, METH_VARARGS, "Processor Data" }, { "memory", dmidecode_get_memory, METH_VARARGS, "Memory Data" }, { "cache", dmidecode_get_cache, METH_VARARGS, "Cache Data" }, { "connector", dmidecode_get_connector, METH_VARARGS, "Connector Data" }, { "slot", dmidecode_get_slot, METH_VARARGS, "Slot Data" }, { NULL, NULL, 0, NULL } }; PyMODINIT_FUNC initdmidecode(void) { (void) Py_InitModule("dmidecode", DMIDataMethods); } /* static PyObject* dmidecode_xget(PyObject *self, PyObject *args) { bzero(buffer, 50000); PyObject *list = PyList_New(0); //const char *command; //if(!PyArg_ParseTuple(args, "s", &command)) // return NULL; //for(i=0; i>> %d: %s\n", i, argv[i]); submain(buffer, argc, argv); PyList_Append(list, PyUnicode_Splitlines(Py_BuildValue("s", buffer), 1)); //PyList_Append(list, PySequence_List(args)); //PyList_Append(list, Py_BuildValue("i", PySequence_Size(args))); return list; } */ /* int submain(char* buffer, int argc, char * const argv[]) { int ret=0; /* Returned value * / int found=0; size_t fp; int efi; u8 *buf; if(sizeof(u8)!=1 || sizeof(u16)!=2 || sizeof(u32)!=4 || '\0'!=0) { fprintf(stderr, "%s: compiler incompatibility\n", argv[0]); exit(255); } /* Set default option values * / opt.devmem=DEFAULT_MEM_DEV; opt.flags=0; if(parse_command_line(argc, argv)<0) { ret=2; goto exit_free; } if(opt.flags & FLAG_HELP) { print_help(); goto exit_free; } if(opt.flags & FLAG_VERSION) { printf("%s\n", VERSION); goto exit_free; } if(!(opt.flags & FLAG_QUIET)) printf("# dmidecode %s\n", VERSION); /* First try EFI (ia64, Intel-based Mac) * / efi=address_from_efi(&fp); switch(efi) { case EFI_NOT_FOUND: goto memory_scan; case EFI_NO_SMBIOS: ret=1; goto exit_free; } if((buf=mem_chunk(fp, 0x20, opt.devmem))==NULL) { ret=1; goto exit_free; } if(smbios_decode(buf, opt.devmem)) found++; goto done; memory_scan: /* Fallback to memory scan (x86, x86_64) * / if((buf=mem_chunk(0xF0000, 0x10000, opt.devmem))==NULL) { ret=1; goto exit_free; } for(fp=0; fp<=0xFFF0; fp+=16) { if(memcmp(buf+fp, "_SM_", 4)==0 && fp<=0xFFE0) { if(smbios_decode(buf+fp, opt.devmem)) found++; fp+=16; } else if(memcmp(buf+fp, "_DMI_", 5)==0) { if (legacy_decode(buf+fp, opt.devmem)) found++; } } done: free(buf); if(!found && !(opt.flags & FLAG_QUIET)) printf("# No SMBIOS nor DMI entry point found, sorry.\n"); exit_free: free(opt.type); return ret; } */