summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornima <nima@abc39116-655e-4be6-ad55-d661dc543056>2008-08-06 06:17:21 +0000
committernima <nima@abc39116-655e-4be6-ad55-d661dc543056>2008-08-06 06:17:21 +0000
commitcfa3d0433906670cffa49bd645cdc3b99383f208 (patch)
treea7693709b11c8945fd7ac4fcd7fb24286036ac13
parenta1554740cea413d44314c861da9b95fd77ea0189 (diff)
downloadpython-dmidecode-cfa3d0433906670cffa49bd645cdc3b99383f208.tar.gz
python-dmidecode-cfa3d0433906670cffa49bd645cdc3b99383f208.tar.xz
python-dmidecode-cfa3d0433906670cffa49bd645cdc3b99383f208.zip
Started on `case 19'.
git-svn-id: svn://svn.autonomy.net.au/python-dmidecode@38 abc39116-655e-4be6-ad55-d661dc543056
-rw-r--r--dmidecode.c54
1 files changed, 27 insertions, 27 deletions
diff --git a/dmidecode.c b/dmidecode.c
index 37da23f..394dcdc 100644
--- a/dmidecode.c
+++ b/dmidecode.c
@@ -2198,47 +2198,47 @@ static PyObject *dmi_32bit_memory_error_address(u32 code) {
** 3.3.20 Memory Array Mapped Address (Type 19)
*/
-static const char *dmi_mapped_address_size(u32 code, char *_) {
- if(code==0)
- catsprintf(_, " Invalid");
- else if((code&0x000FFFFF)==0)
- catsprintf(_, " %u GB", code>>20);
- else if((code&0x000003FF)==0)
- catsprintf(_, " %u MB", code>>10);
- else
- catsprintf(_, " %u kB", code);
- return _;
+static PyObject *dmi_mapped_address_size(u32 code) {
+ PyObject *data;
+ if(code==0) data = PyString_FromString("Invalid");
+ else if((code&0x000FFFFF)==0) data = PyString_FromFormat("%u GB", code>>20);
+ else if((code&0x000003FF)==0) data = PyString_FromFormat("%u MB", code>>10);
+ else data = PyString_FromFormat("%u kB", code);
+ return data;
}
/*******************************************************************************
** 3.3.21 Memory Device Mapped Address (Type 20)
*/
-static const char *dmi_mapped_address_row_position(u8 code, char *_) {
- if(code==0) sprintf(_, " %s", out_of_spec);
- else if(code==0xFF) sprintf(_, " Unknown");
- else sprintf(_, " %u", code);
- return _;
+static PyObject *dmi_mapped_address_row_position(u8 code) {
+ PyObject *data;
+ if(code==0) data = PyString_FromString(out_of_spec);
+ else if(code==0xFF) PyString_FromString("Unknown");
+ else PyInt_FromLong(code);
+ return data;
}
-static const char *dmi_mapped_address_interleave_position(u8 code, char *_) {
- catsprintf(_, NULL);
+static PyObject *dmi_mapped_address_interleave_position(u8 code) {
+ PyObject *data;
if(code!=0) {
- catsprintf(_, "Interleave Position");
- if(code==0xFF) catsprintf(_, "|Unknown");
- else catsprintf(_, "|%u", code);
+ data = PyDict_New();
+ PyDict_Set_ItemString("Interleave Position", (code==0xFF)?PyString_FromString("Unknown"):PyInt_FromLong(code));
+ } else {
+ data = Py_None;
}
- return _;
+ return data;
}
-static const char *dmi_mapped_address_interleaved_data_depth(u8 code, char *_) {
- catsprintf(_, NULL);
+static PyObject *dmi_mapped_address_interleaved_data_depth(u8 code) {
+ PyObject *data;
if(code!=0) {
- catsprintf(_, "Interleaved Data Depth");
- if(code==0xFF) catsprintf(_, "|Unknown");
- else catsprintf(_, "|%u", code);
+ data = PyDict_New();
+ PyDict_Set_ItemString("Interleave Data Depth", (code==0xFF)?PyString_FromString("Unknown"):PyInt_FromLong(code));
+ } else {
+ data = Py_None;
}
- return _;
+ return data;
}
/*******************************************************************************