aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/rfs.h24
-rw-r--r--include/samsung-ipc.h8
-rw-r--r--samsung-ipc/devices/aries/aries_ipc.c10
-rw-r--r--samsung-ipc/devices/aries/aries_ipc.h1
-rw-r--r--samsung-ipc/devices/crespo/crespo_ipc.c10
-rw-r--r--samsung-ipc/devices/crespo/crespo_ipc.h1
-rw-r--r--samsung-ipc/devices/galaxys2/galaxys2_ipc.c10
-rw-r--r--samsung-ipc/devices/galaxys2/galaxys2_ipc.h1
-rw-r--r--samsung-ipc/devices/i9300/i9300_ipc.c10
-rw-r--r--samsung-ipc/devices/i9300/i9300_ipc.h1
-rw-r--r--samsung-ipc/devices/maguro/maguro_ipc.c8
-rw-r--r--samsung-ipc/devices/maguro/maguro_ipc.h5
-rw-r--r--samsung-ipc/devices/n7100/n7100_ipc.c10
-rw-r--r--samsung-ipc/devices/n7100/n7100_ipc.h1
-rw-r--r--samsung-ipc/devices/piranha/piranha_ipc.c10
-rw-r--r--samsung-ipc/devices/piranha/piranha_ipc.h1
-rw-r--r--samsung-ipc/devices/xmm6160/xmm6160.c4
-rw-r--r--samsung-ipc/devices/xmm6160/xmm6160.h8
-rw-r--r--samsung-ipc/devices/xmm6260/xmm6260.h8
-rw-r--r--samsung-ipc/devices/xmm6260/xmm6260_hsic.c4
-rw-r--r--samsung-ipc/devices/xmm6260/xmm6260_mipi.c4
-rw-r--r--samsung-ipc/ipc.c70
-rw-r--r--samsung-ipc/ipc.h5
-rw-r--r--samsung-ipc/ipc_devices.c20
-rw-r--r--samsung-ipc/rfs.c239
25 files changed, 234 insertions, 239 deletions
diff --git a/include/rfs.h b/include/rfs.h
index 3b8971b..d56f05a 100644
--- a/include/rfs.h
+++ b/include/rfs.h
@@ -30,22 +30,6 @@
#define IPC_RFS_NV_WRITE_ITEM 0x4202
/*
- * Values
- */
-
-#define NV_DATA_SIZE_DEFAULT 0x200000
-#define NV_DATA_CHUNK_SIZE_DEFAULT 0x1000
-
-#define NV_DATA_PATH_DEFAULT "/efs/nv_data.bin"
-#define NV_DATA_MD5_PATH_DEFAULT "/efs/nv_data.bin.md5"
-#define NV_DATA_BAK_PATH_DEFAULT "/efs/.nv_data.bak"
-#define NV_DATA_MD5_BAK_PATH_DEFAULT "/efs/.nv_data.bak.md5"
-#define NV_STATE_PATH_DEFAULT "/efs/.nv_state"
-#define NV_DATA_SECRET_DEFAULT "Samsung_Android_RIL"
-
-#define MD5_STRING_SIZE MD5_DIGEST_LENGTH * 2 + 1
-
-/*
* Structures
*/
@@ -76,14 +60,6 @@ struct ipc_rfs_nv_write_item_confirm_data {
*/
void md5hash2string(char *out, unsigned char *in);
-char *nv_data_path(struct ipc_client *client);
-char *nv_data_md5_path(struct ipc_client *client);
-char *nv_data_bak_path(struct ipc_client *client);
-char *nv_data_md5_bak_path(struct ipc_client *client);
-char *nv_state_path(struct ipc_client *client);
-char *nv_data_secret(struct ipc_client *client);
-int nv_data_size(struct ipc_client *client);
-int nv_data_chunk_size(struct ipc_client *client);
void nv_data_generate(struct ipc_client *client);
void nv_data_md5_compute(void *data_p, int size, char *secret, void *hash);
void nv_data_md5_generate(struct ipc_client *client);
diff --git a/include/samsung-ipc.h b/include/samsung-ipc.h
index 2cdc509..f0d7eba 100644
--- a/include/samsung-ipc.h
+++ b/include/samsung-ipc.h
@@ -108,6 +108,14 @@ char *ipc_client_gprs_get_iface(struct ipc_client *client, int cid);
int ipc_client_gprs_get_capabilities(struct ipc_client *client,
struct ipc_client_gprs_capabilities *capabilities);
+char *ipc_client_nv_data_path(struct ipc_client *client);
+char *ipc_client_nv_data_md5_path(struct ipc_client *client);
+char *ipc_client_nv_data_backup_path(struct ipc_client *client);
+char *ipc_client_nv_data_backup_md5_path(struct ipc_client *client);
+char *ipc_client_nv_data_secret(struct ipc_client *client);
+int ipc_client_nv_data_size(struct ipc_client *client);
+int ipc_client_nv_data_chunk_size(struct ipc_client *client);
+
const char *ipc_response_type_to_str(int type);
const char *ipc_request_type_to_str(int type);
const char *ipc_command_to_str(int command);
diff --git a/samsung-ipc/devices/aries/aries_ipc.c b/samsung-ipc/devices/aries/aries_ipc.c
index 97df116..40e03d3 100644
--- a/samsung-ipc/devices/aries/aries_ipc.c
+++ b/samsung-ipc/devices/aries/aries_ipc.c
@@ -803,4 +803,14 @@ struct ipc_gprs_specs aries_ipc_gprs_specs = {
.gprs_get_capabilities = aries_ipc_gprs_get_capabilities,
};
+struct ipc_nv_data_specs aries_ipc_nv_data_specs = {
+ .nv_data_path = XMM6160_NV_DATA_PATH,
+ .nv_data_md5_path = XMM6160_NV_DATA_MD5_PATH,
+ .nv_data_backup_path = XMM6160_NV_DATA_BACKUP_PATH,
+ .nv_data_backup_md5_path = XMM6160_NV_DATA_BACKUP_MD5_PATH,
+ .nv_data_secret = XMM6160_NV_DATA_SECRET,
+ .nv_data_size = XMM6160_NV_DATA_SIZE,
+ .nv_data_chunk_size = XMM6160_NV_DATA_CHUNK_SIZE,
+};
+
// vim:ts=4:sw=4:expandtab
diff --git a/samsung-ipc/devices/aries/aries_ipc.h b/samsung-ipc/devices/aries/aries_ipc.h
index e410dd2..bb42f27 100644
--- a/samsung-ipc/devices/aries/aries_ipc.h
+++ b/samsung-ipc/devices/aries/aries_ipc.h
@@ -58,6 +58,7 @@ extern struct ipc_ops aries_ipc_fmt_ops;
extern struct ipc_ops aries_ipc_rfs_ops;
extern struct ipc_handlers aries_ipc_handlers;
extern struct ipc_gprs_specs aries_ipc_gprs_specs;
+extern struct ipc_nv_data_specs aries_ipc_nv_data_specs;
#endif
diff --git a/samsung-ipc/devices/crespo/crespo_ipc.c b/samsung-ipc/devices/crespo/crespo_ipc.c
index 457cd48..b29c4fc 100644
--- a/samsung-ipc/devices/crespo/crespo_ipc.c
+++ b/samsung-ipc/devices/crespo/crespo_ipc.c
@@ -556,4 +556,14 @@ struct ipc_gprs_specs crespo_ipc_gprs_specs = {
.gprs_get_capabilities = crespo_ipc_gprs_get_capabilities,
};
+struct ipc_nv_data_specs crespo_ipc_nv_data_specs = {
+ .nv_data_path = XMM6160_NV_DATA_PATH,
+ .nv_data_md5_path = XMM6160_NV_DATA_MD5_PATH,
+ .nv_data_backup_path = XMM6160_NV_DATA_BACKUP_PATH,
+ .nv_data_backup_md5_path = XMM6160_NV_DATA_BACKUP_MD5_PATH,
+ .nv_data_secret = XMM6160_NV_DATA_SECRET,
+ .nv_data_size = XMM6160_NV_DATA_SIZE,
+ .nv_data_chunk_size = XMM6160_NV_DATA_CHUNK_SIZE,
+};
+
// vim:ts=4:sw=4:expandtab
diff --git a/samsung-ipc/devices/crespo/crespo_ipc.h b/samsung-ipc/devices/crespo/crespo_ipc.h
index 85bf21d..ff984d8 100644
--- a/samsung-ipc/devices/crespo/crespo_ipc.h
+++ b/samsung-ipc/devices/crespo/crespo_ipc.h
@@ -43,6 +43,7 @@ extern struct ipc_ops crespo_ipc_rfs_ops;
extern struct ipc_handlers crespo_ipc_handlers;
extern struct ipc_gprs_specs crespo_ipc_gprs_specs_single;
extern struct ipc_gprs_specs crespo_ipc_gprs_specs;
+extern struct ipc_nv_data_specs crespo_ipc_nv_data_specs;
#endif
diff --git a/samsung-ipc/devices/galaxys2/galaxys2_ipc.c b/samsung-ipc/devices/galaxys2/galaxys2_ipc.c
index 5c1c9c3..44a315b 100644
--- a/samsung-ipc/devices/galaxys2/galaxys2_ipc.c
+++ b/samsung-ipc/devices/galaxys2/galaxys2_ipc.c
@@ -414,4 +414,14 @@ struct ipc_gprs_specs galaxys2_ipc_gprs_specs = {
.gprs_get_capabilities = galaxys2_ipc_gprs_get_capabilities,
};
+struct ipc_nv_data_specs galaxys2_ipc_nv_data_specs = {
+ .nv_data_path = XMM6260_NV_DATA_PATH,
+ .nv_data_md5_path = XMM6260_NV_DATA_MD5_PATH,
+ .nv_data_backup_path = XMM6260_NV_DATA_BACKUP_PATH,
+ .nv_data_backup_md5_path = XMM6260_NV_DATA_BACKUP_MD5_PATH,
+ .nv_data_secret = XMM6260_NV_DATA_SECRET,
+ .nv_data_size = XMM6260_NV_DATA_SIZE,
+ .nv_data_chunk_size = XMM6260_NV_DATA_CHUNK_SIZE,
+};
+
// vim:ts=4:sw=4:expandtab
diff --git a/samsung-ipc/devices/galaxys2/galaxys2_ipc.h b/samsung-ipc/devices/galaxys2/galaxys2_ipc.h
index b8b6a12..7d68465 100644
--- a/samsung-ipc/devices/galaxys2/galaxys2_ipc.h
+++ b/samsung-ipc/devices/galaxys2/galaxys2_ipc.h
@@ -42,6 +42,7 @@ extern struct ipc_ops galaxys2_ipc_fmt_ops;
extern struct ipc_ops galaxys2_ipc_rfs_ops;
extern struct ipc_handlers galaxys2_ipc_handlers;
extern struct ipc_gprs_specs galaxys2_ipc_gprs_specs;
+extern struct ipc_nv_data_specs galaxys2_ipc_nv_data_specs;
#endif
diff --git a/samsung-ipc/devices/i9300/i9300_ipc.c b/samsung-ipc/devices/i9300/i9300_ipc.c
index 59c2eb5..b7364df 100644
--- a/samsung-ipc/devices/i9300/i9300_ipc.c
+++ b/samsung-ipc/devices/i9300/i9300_ipc.c
@@ -408,4 +408,14 @@ struct ipc_gprs_specs i9300_ipc_gprs_specs = {
.gprs_get_capabilities = i9300_ipc_gprs_get_capabilities,
};
+struct ipc_nv_data_specs i9300_ipc_nv_data_specs = {
+ .nv_data_path = XMM6260_NV_DATA_PATH,
+ .nv_data_md5_path = XMM6260_NV_DATA_MD5_PATH,
+ .nv_data_backup_path = XMM6260_NV_DATA_BACKUP_PATH,
+ .nv_data_backup_md5_path = XMM6260_NV_DATA_BACKUP_MD5_PATH,
+ .nv_data_secret = XMM6260_NV_DATA_SECRET,
+ .nv_data_size = XMM6260_NV_DATA_SIZE,
+ .nv_data_chunk_size = XMM6260_NV_DATA_CHUNK_SIZE,
+};
+
// vim:ts=4:sw=4:expandtab
diff --git a/samsung-ipc/devices/i9300/i9300_ipc.h b/samsung-ipc/devices/i9300/i9300_ipc.h
index 6eceb21..901c28d 100644
--- a/samsung-ipc/devices/i9300/i9300_ipc.h
+++ b/samsung-ipc/devices/i9300/i9300_ipc.h
@@ -42,6 +42,7 @@ extern struct ipc_ops i9300_ipc_fmt_ops;
extern struct ipc_ops i9300_ipc_rfs_ops;
extern struct ipc_handlers i9300_ipc_handlers;
extern struct ipc_gprs_specs i9300_ipc_gprs_specs;
+extern struct ipc_nv_data_specs i9300_ipc_nv_data_specs;
#endif
diff --git a/samsung-ipc/devices/maguro/maguro_ipc.c b/samsung-ipc/devices/maguro/maguro_ipc.c
index 9b824a0..15c72ac 100644
--- a/samsung-ipc/devices/maguro/maguro_ipc.c
+++ b/samsung-ipc/devices/maguro/maguro_ipc.c
@@ -393,9 +393,11 @@ struct ipc_gprs_specs maguro_ipc_gprs_specs = {
struct ipc_nv_data_specs maguro_ipc_nv_data_specs = {
.nv_data_path = MAGURO_NV_DATA_PATH,
.nv_data_md5_path = MAGURO_NV_DATA_MD5_PATH,
- .nv_state_path = MAGURO_NV_STATE_PATH,
- .nv_data_bak_path = MAGURO_NV_DATA_BAK_PATH,
- .nv_data_md5_bak_path = MAGURO_NV_DATA_MD5_BAK_PATH,
+ .nv_data_backup_path = MAGURO_NV_DATA_BACKUP_PATH,
+ .nv_data_backup_md5_path = MAGURO_NV_DATA_BACKUP_MD5_PATH,
+ .nv_data_secret = XMM6260_NV_DATA_SECRET,
+ .nv_data_size = XMM6260_NV_DATA_SIZE,
+ .nv_data_chunk_size = XMM6260_NV_DATA_CHUNK_SIZE,
};
// vim:ts=4:sw=4:expandtab
diff --git a/samsung-ipc/devices/maguro/maguro_ipc.h b/samsung-ipc/devices/maguro/maguro_ipc.h
index 67836ba..c58178c 100644
--- a/samsung-ipc/devices/maguro/maguro_ipc.h
+++ b/samsung-ipc/devices/maguro/maguro_ipc.h
@@ -38,9 +38,8 @@
#define MAGURO_NV_DATA_PATH "/factory/nv_data.bin"
#define MAGURO_NV_DATA_MD5_PATH "/factory/nv_data.bin.md5"
-#define MAGURO_NV_STATE_PATH "/factory/.nv_state"
-#define MAGURO_NV_DATA_BAK_PATH "/factory/.nv_data.bak"
-#define MAGURO_NV_DATA_MD5_BAK_PATH "/factory/.nv_data.bak.md5"
+#define MAGURO_NV_DATA_BACKUP_PATH "/factory/.nv_data.bak"
+#define MAGURO_NV_DATA_BACKUP_MD5_PATH "/factory/.nv_data.bak.md5"
struct maguro_ipc_transport_data {
int fd;
diff --git a/samsung-ipc/devices/n7100/n7100_ipc.c b/samsung-ipc/devices/n7100/n7100_ipc.c
index 03c30dc..ad118da 100644
--- a/samsung-ipc/devices/n7100/n7100_ipc.c
+++ b/samsung-ipc/devices/n7100/n7100_ipc.c
@@ -408,4 +408,14 @@ struct ipc_gprs_specs n7100_ipc_gprs_specs = {
.gprs_get_capabilities = n7100_ipc_gprs_get_capabilities,
};
+struct ipc_nv_data_specs n7100_ipc_nv_data_specs = {
+ .nv_data_path = XMM6260_NV_DATA_PATH,
+ .nv_data_md5_path = XMM6260_NV_DATA_MD5_PATH,
+ .nv_data_backup_path = XMM6260_NV_DATA_BACKUP_PATH,
+ .nv_data_backup_md5_path = XMM6260_NV_DATA_BACKUP_MD5_PATH,
+ .nv_data_secret = XMM6260_NV_DATA_SECRET,
+ .nv_data_size = XMM6260_NV_DATA_SIZE,
+ .nv_data_chunk_size = XMM6260_NV_DATA_CHUNK_SIZE,
+};
+
// vim:ts=4:sw=4:expandtab
diff --git a/samsung-ipc/devices/n7100/n7100_ipc.h b/samsung-ipc/devices/n7100/n7100_ipc.h
index a081315..0008627 100644
--- a/samsung-ipc/devices/n7100/n7100_ipc.h
+++ b/samsung-ipc/devices/n7100/n7100_ipc.h
@@ -42,6 +42,7 @@ extern struct ipc_ops n7100_ipc_fmt_ops;
extern struct ipc_ops n7100_ipc_rfs_ops;
extern struct ipc_handlers n7100_ipc_handlers;
extern struct ipc_gprs_specs n7100_ipc_gprs_specs;
+extern struct ipc_nv_data_specs n7100_ipc_nv_data_specs;
#endif
diff --git a/samsung-ipc/devices/piranha/piranha_ipc.c b/samsung-ipc/devices/piranha/piranha_ipc.c
index 5bdd0cd..88754dd 100644
--- a/samsung-ipc/devices/piranha/piranha_ipc.c
+++ b/samsung-ipc/devices/piranha/piranha_ipc.c
@@ -355,4 +355,14 @@ struct ipc_gprs_specs piranha_ipc_gprs_specs = {
.gprs_get_capabilities = piranha_ipc_gprs_get_capabilities,
};
+struct ipc_nv_data_specs piranha_ipc_nv_data_specs = {
+ .nv_data_path = XMM6260_NV_DATA_PATH,
+ .nv_data_md5_path = XMM6260_NV_DATA_MD5_PATH,
+ .nv_data_backup_path = XMM6260_NV_DATA_BACKUP_PATH,
+ .nv_data_backup_md5_path = XMM6260_NV_DATA_BACKUP_MD5_PATH,
+ .nv_data_secret = XMM6260_NV_DATA_SECRET,
+ .nv_data_size = XMM6260_NV_DATA_SIZE,
+ .nv_data_chunk_size = XMM6260_NV_DATA_CHUNK_SIZE,
+};
+
// vim:ts=4:sw=4:expandtab
diff --git a/samsung-ipc/devices/piranha/piranha_ipc.h b/samsung-ipc/devices/piranha/piranha_ipc.h
index 5c857fc..7cff520 100644
--- a/samsung-ipc/devices/piranha/piranha_ipc.h
+++ b/samsung-ipc/devices/piranha/piranha_ipc.h
@@ -43,6 +43,7 @@ extern struct ipc_ops piranha_ipc_rfs_ops;
extern struct ipc_handlers piranha_ipc_handlers;
extern struct ipc_gprs_specs piranha_ipc_gprs_specs;
extern struct ipc_nv_data_specs piranha_ipc_nv_data_specs;
+extern struct ipc_nv_data_specs piranha_ipc_nv_data_specs;
#endif
diff --git a/samsung-ipc/devices/xmm6160/xmm6160.c b/samsung-ipc/devices/xmm6160/xmm6160.c
index 8374541..2af6837 100644
--- a/samsung-ipc/devices/xmm6160/xmm6160.c
+++ b/samsung-ipc/devices/xmm6160/xmm6160.c
@@ -252,7 +252,7 @@ int xmm6160_nv_data_send(struct ipc_client *client, int device_fd,
}
ipc_client_log(client, "Checked nv_data md5");
- nv_data = file_data_read(nv_data_path(client), nv_data_size(client), nv_data_chunk_size(client));
+ nv_data = file_data_read(ipc_client_nv_data_path(client), ipc_client_nv_data_size(client), ipc_client_nv_data_chunk_size(client));
if (nv_data == NULL) {
ipc_client_log(client, "Reading nv_data failed");
goto error;
@@ -260,7 +260,7 @@ int xmm6160_nv_data_send(struct ipc_client *client, int device_fd,
ipc_client_log(client, "Read nv_data");
p = (unsigned char *) nv_data;
- nv_size = nv_data_size(client);
+ nv_size = ipc_client_nv_data_size(client);
if (device_address != NULL) {
memcpy(device_address, p, nv_size);
diff --git a/samsung-ipc/devices/xmm6160/xmm6160.h b/samsung-ipc/devices/xmm6160/xmm6160.h
index 2d2bdf9..14f337a 100644
--- a/samsung-ipc/devices/xmm6160/xmm6160.h
+++ b/samsung-ipc/devices/xmm6160/xmm6160.h
@@ -28,6 +28,14 @@
#define XMM6160_PSI_ACK 0x01
#define XMM6160_BOOTCORE_VERSION 0xF0
+#define XMM6160_NV_DATA_PATH "/efs/nv_data.bin"
+#define XMM6160_NV_DATA_MD5_PATH "/efs/nv_data.bin.md5"
+#define XMM6160_NV_DATA_BACKUP_PATH "/efs/.nv_data.bak"
+#define XMM6160_NV_DATA_BACKUP_MD5_PATH "/efs/.nv_data.bak.md5"
+#define XMM6160_NV_DATA_SECRET "Samsung_Android_RIL"
+#define XMM6160_NV_DATA_SIZE 0x200000
+#define XMM6160_NV_DATA_CHUNK_SIZE 0x1000
+
int xmm6160_psi_send(struct ipc_client *client, int serial_fd,
void *psi_data, unsigned short psi_size);
int xmm6160_firmware_send(struct ipc_client *client, int device_fd,
diff --git a/samsung-ipc/devices/xmm6260/xmm6260.h b/samsung-ipc/devices/xmm6260/xmm6260.h
index 64f7938..c116ede 100644
--- a/samsung-ipc/devices/xmm6260/xmm6260.h
+++ b/samsung-ipc/devices/xmm6260/xmm6260.h
@@ -38,6 +38,14 @@
#define XMM6260_NV_DATA_ADDRESS 0x60E80000
#define XMM6260_MPS_DATA_ADDRESS 0x61080000
+#define XMM6260_NV_DATA_PATH "/efs/nv_data.bin"
+#define XMM6260_NV_DATA_MD5_PATH "/efs/nv_data.bin.md5"
+#define XMM6260_NV_DATA_BACKUP_PATH "/efs/.nv_data.bak"
+#define XMM6260_NV_DATA_BACKUP_MD5_PATH "/efs/.nv_data.bak.md5"
+#define XMM6260_NV_DATA_SECRET "Samsung_Android_RIL"
+#define XMM6260_NV_DATA_SIZE 0x200000
+#define XMM6260_NV_DATA_CHUNK_SIZE 0x1000
+
unsigned char xmm6260_crc_calculate(void *buffer, int length);
#endif
diff --git a/samsung-ipc/devices/xmm6260/xmm6260_hsic.c b/samsung-ipc/devices/xmm6260/xmm6260_hsic.c
index e4162ae..ed3b453 100644
--- a/samsung-ipc/devices/xmm6260/xmm6260_hsic.c
+++ b/samsung-ipc/devices/xmm6260/xmm6260_hsic.c
@@ -561,14 +561,14 @@ int xmm6260_hsic_nv_data_send(struct ipc_client *client, int device_fd)
}
ipc_client_log(client, "Checked nv_data md5");
- nv_data = file_data_read(nv_data_path(client), nv_data_size(client), nv_data_chunk_size(client));
+ nv_data = file_data_read(ipc_client_nv_data_path(client), ipc_client_nv_data_size(client), ipc_client_nv_data_chunk_size(client));
if (nv_data == NULL) {
ipc_client_log(client, "Reading nv_data failed");
goto error;
}
ipc_client_log(client, "Read nv_data");
- nv_size = nv_data_size(client);
+ nv_size = ipc_client_nv_data_size(client);
rc = xmm6260_hsic_modem_data_send(device_fd, nv_data, nv_size, XMM6260_NV_DATA_ADDRESS);
if (rc < 0)
diff --git a/samsung-ipc/devices/xmm6260/xmm6260_mipi.c b/samsung-ipc/devices/xmm6260/xmm6260_mipi.c
index df31755..4f11361 100644
--- a/samsung-ipc/devices/xmm6260/xmm6260_mipi.c
+++ b/samsung-ipc/devices/xmm6260/xmm6260_mipi.c
@@ -611,14 +611,14 @@ int xmm6260_mipi_nv_data_send(struct ipc_client *client, int device_fd)
}
ipc_client_log(client, "Checked nv_data md5");
- nv_data = file_data_read(nv_data_path(client), nv_data_size(client), nv_data_chunk_size(client));
+ nv_data = file_data_read(ipc_client_nv_data_path(client), ipc_client_nv_data_size(client), ipc_client_nv_data_chunk_size(client));
if (nv_data == NULL) {
ipc_client_log(client, "Reading nv_data failed");
goto error;
}
ipc_client_log(client, "Read nv_data");
- nv_size = nv_data_size(client);
+ nv_size = ipc_client_nv_data_size(client);
rc = xmm6260_mipi_modem_data_send(device_fd, nv_data, nv_size, XMM6260_NV_DATA_ADDRESS);
if (rc < 0)
diff --git a/samsung-ipc/ipc.c b/samsung-ipc/ipc.c
index 26716af..553880f 100644
--- a/samsung-ipc/ipc.c
+++ b/samsung-ipc/ipc.c
@@ -444,4 +444,74 @@ int ipc_client_gprs_get_capabilities(struct ipc_client *client,
return client->gprs_specs->gprs_get_capabilities(capabilities);
}
+char *ipc_client_nv_data_path(struct ipc_client *client)
+{
+ if (client == NULL ||
+ client->nv_data_specs == NULL ||
+ client->nv_data_specs->nv_data_path == NULL)
+ return NULL;
+
+ return client->nv_data_specs->nv_data_path;
+}
+
+char *ipc_client_nv_data_md5_path(struct ipc_client *client)
+{
+ if (client == NULL ||
+ client->nv_data_specs == NULL ||
+ client->nv_data_specs->nv_data_md5_path == NULL)
+ return NULL;
+
+ return client->nv_data_specs->nv_data_md5_path;
+}
+
+char *ipc_client_nv_data_backup_path(struct ipc_client *client)
+{
+ if (client == NULL ||
+ client->nv_data_specs == NULL ||
+ client->nv_data_specs->nv_data_backup_path == NULL)
+ return NULL;
+
+ return client->nv_data_specs->nv_data_backup_path;
+}
+
+char *ipc_client_nv_data_backup_md5_path(struct ipc_client *client)
+{
+ if (client == NULL ||
+ client->nv_data_specs == NULL ||
+ client->nv_data_specs->nv_data_backup_md5_path == NULL)
+ return NULL;
+
+ return client->nv_data_specs->nv_data_backup_md5_path;
+}
+
+char *ipc_client_nv_data_secret(struct ipc_client *client)
+{
+ if (client == NULL ||
+ client->nv_data_specs == NULL ||
+ client->nv_data_specs->nv_data_secret == NULL)
+ return NULL;
+
+ return client->nv_data_specs->nv_data_secret;
+}
+
+int ipc_client_nv_data_size(struct ipc_client *client)
+{
+ if (client == NULL ||
+ client->nv_data_specs == NULL ||
+ client->nv_data_specs->nv_data_size == 0)
+ return -1;
+
+ return client->nv_data_specs->nv_data_size;
+}
+
+int ipc_client_nv_data_chunk_size(struct ipc_client *client)
+{
+ if (client == NULL ||
+ client->nv_data_specs == NULL ||
+ client->nv_data_specs->nv_data_chunk_size == 0)
+ return -1;
+
+ return client->nv_data_specs->nv_data_chunk_size;
+}
+
// vim:ts=4:sw=4:expandtab
diff --git a/samsung-ipc/ipc.h b/samsung-ipc/ipc.h
index 7e98004..0017994 100644
--- a/samsung-ipc/ipc.h
+++ b/samsung-ipc/ipc.h
@@ -71,9 +71,8 @@ struct ipc_gprs_specs {
struct ipc_nv_data_specs {
char *nv_data_path;
char *nv_data_md5_path;
- char *nv_data_bak_path;
- char *nv_data_md5_bak_path;
- char *nv_state_path;
+ char *nv_data_backup_path;
+ char *nv_data_backup_md5_path;
char *nv_data_secret;
int nv_data_size;
int nv_data_chunk_size;
diff --git a/samsung-ipc/ipc_devices.c b/samsung-ipc/ipc_devices.c
index 13044c9..dec61c2 100644
--- a/samsung-ipc/ipc_devices.c
+++ b/samsung-ipc/ipc_devices.c
@@ -32,7 +32,7 @@ struct ipc_device_desc ipc_devices[] = {
.rfs_ops = &crespo_ipc_rfs_ops,
.handlers = &crespo_ipc_handlers,
.gprs_specs = &crespo_ipc_gprs_specs_single,
- .nv_data_specs = NULL,
+ .nv_data_specs = &crespo_ipc_nv_data_specs,
},
{
.name = "crespo",
@@ -42,7 +42,7 @@ struct ipc_device_desc ipc_devices[] = {
.rfs_ops = &crespo_ipc_rfs_ops,
.handlers = &crespo_ipc_handlers,
.gprs_specs = &crespo_ipc_gprs_specs,
- .nv_data_specs = NULL,
+ .nv_data_specs = &crespo_ipc_nv_data_specs,
},
{
.name = "aries",
@@ -52,7 +52,7 @@ struct ipc_device_desc ipc_devices[] = {
.rfs_ops = &aries_ipc_rfs_ops,
.handlers = &aries_ipc_handlers,
.gprs_specs = &aries_ipc_gprs_specs,
- .nv_data_specs = NULL,
+ .nv_data_specs = &aries_ipc_nv_data_specs,
},
{
.name = "aries",
@@ -62,7 +62,7 @@ struct ipc_device_desc ipc_devices[] = {
.rfs_ops = &aries_ipc_rfs_ops,
.handlers = &aries_ipc_handlers,
.gprs_specs = &aries_ipc_gprs_specs,
- .nv_data_specs = NULL,
+ .nv_data_specs = &aries_ipc_nv_data_specs,
},
{
.name = "galaxys2",
@@ -72,7 +72,7 @@ struct ipc_device_desc ipc_devices[] = {
.rfs_ops = &galaxys2_ipc_rfs_ops,
.handlers = &galaxys2_ipc_handlers,
.gprs_specs = &galaxys2_ipc_gprs_specs,
- .nv_data_specs = NULL,
+ .nv_data_specs = &galaxys2_ipc_nv_data_specs,
},
{
.name = "galaxys2",
@@ -82,7 +82,7 @@ struct ipc_device_desc ipc_devices[] = {
.rfs_ops = &galaxys2_ipc_rfs_ops,
.handlers = &galaxys2_ipc_handlers,
.gprs_specs = &galaxys2_ipc_gprs_specs,
- .nv_data_specs = NULL,
+ .nv_data_specs = &galaxys2_ipc_nv_data_specs,
},
{
.name = "maguro",
@@ -102,7 +102,7 @@ struct ipc_device_desc ipc_devices[] = {
.rfs_ops = &piranha_ipc_rfs_ops,
.handlers = &piranha_ipc_handlers,
.gprs_specs = &piranha_ipc_gprs_specs,
- .nv_data_specs = NULL,
+ .nv_data_specs = &piranha_ipc_nv_data_specs,
},
{
.name = "piranha",
@@ -112,7 +112,7 @@ struct ipc_device_desc ipc_devices[] = {
.rfs_ops = &piranha_ipc_rfs_ops,
.handlers = &piranha_ipc_handlers,
.gprs_specs = &piranha_ipc_gprs_specs,
- .nv_data_specs = NULL,
+ .nv_data_specs = &piranha_ipc_nv_data_specs,
},
{
.name = "i9300",
@@ -122,7 +122,7 @@ struct ipc_device_desc ipc_devices[] = {
.rfs_ops = &i9300_ipc_rfs_ops,
.handlers = &i9300_ipc_handlers,
.gprs_specs = &i9300_ipc_gprs_specs,
- .nv_data_specs = NULL,
+ .nv_data_specs = &i9300_ipc_nv_data_specs,
},
{
.name = "n7100",
@@ -132,7 +132,7 @@ struct ipc_device_desc ipc_devices[] = {
.rfs_ops = &n7100_ipc_rfs_ops,
.handlers = &n7100_ipc_handlers,
.gprs_specs = &n7100_ipc_gprs_specs,
- .nv_data_specs = NULL,
+ .nv_data_specs = &n7100_ipc_nv_data_specs,
},
};
diff --git a/samsung-ipc/rfs.c b/samsung-ipc/rfs.c
index 0607abe..a386775 100644
--- a/samsung-ipc/rfs.c
+++ b/samsung-ipc/rfs.c
@@ -33,6 +33,8 @@
#include "ipc.h"
#include "util.h"
+#define MD5_STRING_SIZE MD5_DIGEST_LENGTH * 2 + 1
+
void md5hash2string(char *out, unsigned char *in)
{
int i;
@@ -50,86 +52,6 @@ void md5hash2string(char *out, unsigned char *in)
}
}
-char *nv_data_path(struct ipc_client *client)
-{
- if (client == NULL ||
- client->nv_data_specs == NULL ||
- client->nv_data_specs->nv_data_path == NULL)
- return NV_DATA_PATH_DEFAULT;
-
- return client->nv_data_specs->nv_data_path;
-}
-
-char *nv_data_md5_path(struct ipc_client *client)
-{
- if (client == NULL ||
- client->nv_data_specs == NULL ||
- client->nv_data_specs->nv_data_md5_path == NULL)
- return NV_DATA_MD5_PATH_DEFAULT;
-
- return client->nv_data_specs->nv_data_md5_path;
-}
-
-char *nv_data_bak_path(struct ipc_client *client)
-{
- if (client == NULL ||
- client->nv_data_specs == NULL ||
- client->nv_data_specs->nv_data_bak_path == NULL)
- return NV_DATA_BAK_PATH_DEFAULT;
-
- return client->nv_data_specs->nv_data_bak_path;
-}
-
-char *nv_data_md5_bak_path(struct ipc_client *client)
-{
- if (client == NULL ||
- client->nv_data_specs == NULL ||
- client->nv_data_specs->nv_data_md5_bak_path == NULL)
- return NV_DATA_MD5_BAK_PATH_DEFAULT;
-
- return client->nv_data_specs->nv_data_md5_bak_path;
-}
-
-char *nv_state_path(struct ipc_client *client)
-{
- if (client == NULL ||
- client->nv_data_specs == NULL ||
- client->nv_data_specs->nv_state_path == NULL)
- return NV_STATE_PATH_DEFAULT;
-
- return client->nv_data_specs->nv_state_path;
-}
-
-char *nv_data_secret(struct ipc_client *client)
-{
- if (client == NULL ||
- client->nv_data_specs == NULL ||
- client->nv_data_specs->nv_data_secret == NULL)
- return NV_DATA_SECRET_DEFAULT;
-
- return client->nv_data_specs->nv_data_secret;
-}
-
-int nv_data_size(struct ipc_client *client)
-{
- if (client == NULL ||
- client->nv_data_specs == NULL ||
- client->nv_data_specs->nv_data_size == 0)
- return NV_DATA_SIZE_DEFAULT;
-
- return client->nv_data_specs->nv_data_size;
-}
-
-int nv_data_chunk_size(struct ipc_client *client)
-{
- if (client == NULL ||
- client->nv_data_specs == NULL ||
- client->nv_data_specs->nv_data_chunk_size == 0)
- return NV_DATA_CHUNK_SIZE_DEFAULT;
-
- return client->nv_data_specs->nv_data_chunk_size;
-}
-
void nv_data_generate(struct ipc_client *client)
{
return;
@@ -156,9 +78,9 @@ void nv_data_md5_generate(struct ipc_client *client)
ipc_client_log(client, "nv_data_md5_generate: enter");
ipc_client_log(client, "nv_data_md5_generate: generating MD5 hash");
- nv_data_p = file_data_read(nv_data_path(client),
- nv_data_size(client), nv_data_chunk_size(client));
- nv_data_md5_compute(nv_data_p, nv_data_size(client), nv_data_secret(client), nv_data_md5_hash);
+ nv_data_p = file_data_read(ipc_client_nv_data_path(client),
+ ipc_client_nv_data_size(client), ipc_client_nv_data_chunk_size(client));
+ nv_data_md5_compute(nv_data_p, ipc_client_nv_data_size(client), ipc_client_nv_data_secret(client), nv_data_md5_hash);
free(nv_data_p);
/* Alloc the memory for the md5 hash string. */
@@ -172,7 +94,7 @@ void nv_data_md5_generate(struct ipc_client *client)
ipc_client_log(client, "nv_data_md5_generate: writing MD5 hash");
/* Write the MD5 hash in nv_data.bin.md5. */
- fd = open(nv_data_md5_path(client), O_RDWR | O_CREAT | O_TRUNC, 0644);
+ fd = open(ipc_client_nv_data_md5_path(client), O_RDWR | O_CREAT | O_TRUNC, 0644);
if (fd < 0)
{
ipc_client_log(client, "nv_data_md5_generate: fd open failed");
@@ -214,20 +136,20 @@ void nv_data_backup_create(struct ipc_client *client)
ipc_client_log(client, "nv_data_backup_create: enter");
- if (stat(nv_data_path(client), &nv_stat) < 0)
+ if (stat(ipc_client_nv_data_path(client), &nv_stat) < 0)
{
ipc_client_log(client, "nv_data_backup_create: nv_data.bin missing");
nv_data_generate(client);
}
- if (nv_stat.st_size != nv_data_size(client))
+ if (nv_stat.st_size != ipc_client_nv_data_size(client))
{
ipc_client_log(client, "nv_data_backup_create: wrong nv_data.bin size");
nv_data_generate(client);
return;
}
- if (stat(nv_data_md5_path(client), &nv_stat) < 0)
+ if (stat(ipc_client_nv_data_md5_path(client), &nv_stat) < 0)
{
ipc_client_log(client, "nv_data_backup_create: nv_data.bin.md5 missing");
nv_data_generate(client);
@@ -242,15 +164,15 @@ void nv_data_backup_create(struct ipc_client *client)
memset(nv_data_md5_hash_string, 0, MD5_STRING_SIZE);
/* Read the content of the backup file. */
- nv_data_p = file_data_read(nv_data_path(client),
- nv_data_size(client), nv_data_chunk_size(client));
+ nv_data_p = file_data_read(ipc_client_nv_data_path(client),
+ ipc_client_nv_data_size(client), ipc_client_nv_data_chunk_size(client));
/* Compute the backup file MD5 hash. */
- nv_data_md5_compute(nv_data_p, nv_data_size(client), nv_data_secret(client), nv_data_md5_hash);
+ nv_data_md5_compute(nv_data_p, ipc_client_nv_data_size(client), ipc_client_nv_data_secret(client), nv_data_md5_hash);
md5hash2string(nv_data_md5_hash_string, nv_data_md5_hash);
/* Read the stored backup file MD5 hash. */
- fd = open(nv_data_md5_path(client), O_RDONLY);
+ fd = open(ipc_client_nv_data_md5_path(client), O_RDONLY);
if (fd < 0)
{
ipc_client_log(client, "nv_data_backup_create: failed to openstored backup file with MD5 hash");
@@ -278,7 +200,7 @@ void nv_data_backup_create(struct ipc_client *client)
ipc_client_log(client, "nv_data_backup_create: MD5 hash mismatch on backup file");
ipc_client_log(client, "nv_data_backup_create: Consider the computed one as correct");
- fd = open(nv_data_md5_path(client), O_WRONLY);
+ fd = open(ipc_client_nv_data_md5_path(client), O_WRONLY);
if (fd < 0)
{
ipc_client_log(client, "nv_data_backup_create: failed to open file with MD5 hash of data file");
@@ -310,7 +232,7 @@ nv_data_backup_create_write:
{
ipc_client_log(client, "nv_data_backup_create: .nv_data.bak write try #%d", nv_data_write_tries + 1);
- fd = open(nv_data_bak_path(client), O_RDWR | O_CREAT | O_TRUNC, 0644);
+ fd = open(ipc_client_nv_data_backup_path(client), O_RDWR | O_CREAT | O_TRUNC, 0644);
if (fd < 0)
{
ipc_client_log(client, "nv_data_backup_create: negative fd while opening /efs/.nv_data.bak, error: %s", strerror(errno));
@@ -318,8 +240,8 @@ nv_data_backup_create_write:
continue;
}
- rc = write(fd, nv_data_p, nv_data_size(client));
- if (rc < nv_data_size(client))
+ rc = write(fd, nv_data_p, ipc_client_nv_data_size(client));
+ if (rc < ipc_client_nv_data_size(client))
{
ipc_client_log(client, "nv_data_backup_create: wrote less (%d) than what we expected (%d) on /efs/.nv_data.bak, error: %s", strerror(errno));
close(fd);
@@ -334,16 +256,16 @@ nv_data_backup_create_write:
if (nv_data_write_tries == 5)
{
ipc_client_log(client, "nv_data_backup_create: writing nv_data.bin to .nv_data.bak failed too many times");
- unlink(nv_data_bak_path(client));
+ unlink(ipc_client_nv_data_backup_path(client));
goto exit;
}
/* Read the newly-written .nv_data.bak. */
- nv_data_bak_p = file_data_read(nv_data_bak_path(client),
- nv_data_size(client), nv_data_chunk_size(client));
+ nv_data_bak_p = file_data_read(ipc_client_nv_data_backup_path(client),
+ ipc_client_nv_data_size(client), ipc_client_nv_data_chunk_size(client));
/* Compute the MD5 hash for nv_data.bin. */
- nv_data_md5_compute(nv_data_bak_p, nv_data_size(client), nv_data_secret(client), nv_data_md5_hash);
+ nv_data_md5_compute(nv_data_bak_p, ipc_client_nv_data_size(client), ipc_client_nv_data_secret(client), nv_data_md5_hash);
md5hash2string(nv_data_md5_hash_string, nv_data_md5_hash);
if (nv_data_bak_p != NULL)
@@ -362,7 +284,7 @@ nv_data_backup_create_write:
}
/* Write the MD5 hash in .nv_data.bak.md5. */
- fd = open(nv_data_md5_bak_path(client), O_WRONLY | O_CREAT | O_TRUNC, 0644);
+ fd = open(ipc_client_nv_data_backup_md5_path(client), O_WRONLY | O_CREAT | O_TRUNC, 0644);
if (fd < 0)
{
ipc_client_log(client, "nv_data_backup_create: failed to open MD5 hash file");
@@ -378,25 +300,6 @@ nv_data_backup_create_write:
}
close(fd);
- /* Write the correct .nv_state. */
- fd = open(nv_state_path(client), O_WRONLY | O_CREAT | O_TRUNC, 0644);
- if (fd < 0)
- {
- ipc_client_log(client, "nv_data_backup_create: failed to open NV state file");
- goto exit;
- }
-
- data = '1';
- rc = write(fd, &data, sizeof(data));
- if (rc < 0)
- {
- ipc_client_log(client, "nv_data_backup_create: failed to write state of NV data");
- close(fd);
- goto exit;
- }
-
- close(fd);
-
exit:
if (nv_data_p != NULL)
free(nv_data_p);
@@ -426,7 +329,7 @@ void nv_data_backup_restore(struct ipc_client *client)
ipc_client_log(client, "nv_data_backup_restore: enter");
- if (stat(nv_data_bak_path(client), &nv_stat) < 0)
+ if (stat(ipc_client_nv_data_backup_path(client), &nv_stat) < 0)
{
ipc_client_log(client, "nv_data_backup_restore: .nv_data.bak missing");
nv_data_generate(client);
@@ -434,7 +337,7 @@ void nv_data_backup_restore(struct ipc_client *client)
return;
}
- if (nv_stat.st_size != nv_data_size(client))
+ if (nv_stat.st_size != ipc_client_nv_data_size(client))
{
ipc_client_log(client, "nv_data_backup_restore: wrong .nv_data.bak size");
nv_data_generate(client);
@@ -442,7 +345,7 @@ void nv_data_backup_restore(struct ipc_client *client)
return;
}
- if (stat(nv_data_md5_bak_path(client), &nv_stat) < 0)
+ if (stat(ipc_client_nv_data_backup_md5_path(client), &nv_stat) < 0)
{
ipc_client_log(client, "nv_data_backup_restore: .nv_data.bak.md5 missing");
nv_data_generate(client);
@@ -458,15 +361,15 @@ void nv_data_backup_restore(struct ipc_client *client)
memset(nv_data_md5_hash_string, 0, MD5_STRING_SIZE);
/* Read the content of the backup file. */
- nv_data_bak_p = file_data_read(nv_data_bak_path(client),
- nv_data_size(client), nv_data_chunk_size(client));
+ nv_data_bak_p = file_data_read(ipc_client_nv_data_backup_path(client),
+ ipc_client_nv_data_size(client), ipc_client_nv_data_chunk_size(client));
/* Compute the backup file MD5 hash. */
- nv_data_md5_compute(nv_data_bak_p, nv_data_size(client), nv_data_secret(client), nv_data_md5_hash);
+ nv_data_md5_compute(nv_data_bak_p, ipc_client_nv_data_size(client), ipc_client_nv_data_secret(client), nv_data_md5_hash);
md5hash2string(nv_data_md5_hash_string, nv_data_md5_hash);
/* Read the stored backup file MD5 hash. */
- fd = open(nv_data_md5_bak_path(client), O_RDONLY);
+ fd = open(ipc_client_nv_data_backup_md5_path(client), O_RDONLY);
rc = read(fd, nv_data_md5_hash_read, MD5_STRING_SIZE);
if (rc < 0)
{
@@ -488,7 +391,7 @@ void nv_data_backup_restore(struct ipc_client *client)
ipc_client_log(client, "nv_data_backup_restore: MD5 hash mismatch on backup file");
ipc_client_log(client, "nv_data_backup_restore: Consider the computed one as correct");
- fd = open(nv_data_md5_bak_path(client), O_WRONLY);
+ fd = open(ipc_client_nv_data_backup_md5_path(client), O_WRONLY);
if (fd < 0)
{
ipc_client_log(client, "nv_data_backup_restore: failed to open MD5 hash backup file");
@@ -521,7 +424,7 @@ nv_data_backup_restore_write:
{
ipc_client_log(client, "nv_data_backup_restore: nv_data.bin write try #%d", nv_data_write_tries + 1);
- fd = open(nv_data_path(client), O_RDWR | O_CREAT | O_TRUNC, 0644);
+ fd = open(ipc_client_nv_data_path(client), O_RDWR | O_CREAT | O_TRUNC, 0644);
if (fd < 0)
{
ipc_client_log(client, "nv_data_backup_restore: negative fd while opening /efs/nv_data.bin, error: %s", strerror(errno));
@@ -529,8 +432,8 @@ nv_data_backup_restore_write:
continue;
}
- rc = write(fd, nv_data_bak_p, nv_data_size(client));
- if (rc < nv_data_size(client))
+ rc = write(fd, nv_data_bak_p, ipc_client_nv_data_size(client));
+ if (rc < ipc_client_nv_data_size(client))
{
ipc_client_log(client, "nv_data_backup_restore: wrote less (%d) than what we expected (%d) on /efs/nv_data.bin, error: %s", strerror(errno));
close(fd);
@@ -545,16 +448,16 @@ nv_data_backup_restore_write:
if (nv_data_write_tries == 5)
{
ipc_client_log(client, "nv_data_backup_restore: writing the backup to nv_data.bin failed too many times");
- unlink(nv_data_path(client));
+ unlink(ipc_client_nv_data_path(client));
goto exit;
}
/* Read the newly-written nv_data.bin. */
- nv_data_p = file_data_read(nv_data_path(client),
- nv_data_size(client), nv_data_chunk_size(client));
+ nv_data_p = file_data_read(ipc_client_nv_data_path(client),
+ ipc_client_nv_data_size(client), ipc_client_nv_data_chunk_size(client));
/* Compute the MD5 hash for nv_data.bin. */
- nv_data_md5_compute(nv_data_p, nv_data_size(client), nv_data_secret(client), nv_data_md5_hash);
+ nv_data_md5_compute(nv_data_p, ipc_client_nv_data_size(client), ipc_client_nv_data_secret(client), nv_data_md5_hash);
md5hash2string(nv_data_md5_hash_string, nv_data_md5_hash);
if (nv_data_p != NULL)
@@ -576,7 +479,7 @@ nv_data_backup_restore_write:
}
/* Write the MD5 hash in nv_data.bin.md5. */
- fd = open(nv_data_md5_path(client), O_WRONLY | O_CREAT | O_TRUNC, 0644);
+ fd = open(ipc_client_nv_data_md5_path(client), O_WRONLY | O_CREAT | O_TRUNC, 0644);
if (fd < 0)
{
ipc_client_log(client, "nv_data_backup_restore: failed to open file with MD5 hash");
@@ -592,25 +495,6 @@ nv_data_backup_restore_write:
}
close(fd);
- /* Write the correct .nv_state. */
- fd = open(nv_state_path(client), O_WRONLY | O_CREAT | O_TRUNC, 0644);
- if (fd < 0)
- {
- ipc_client_log(client, "nv_data_backup_restore: failed to open NV state file");
- goto exit;
- }
-
- data = '1';
- rc = write(fd, &data, sizeof(data));
- if (rc < 0)
- {
- ipc_client_log(client, "nv_data_backup_restore: failed to write state to file");
- close(fd);
- goto exit;
- }
-
- close(fd);
-
exit:
if (nv_data_bak_p != NULL)
free(nv_data_bak_p);
@@ -625,60 +509,35 @@ exit:
int nv_data_check(struct ipc_client *client)
{
struct stat nv_stat;
- int nv_state_fd = -1;
- int nv_state = 0;
int rc;
ipc_client_log(client, "nv_data_check: enter");
- if (stat(nv_data_path(client), &nv_stat) < 0)
+ if (stat(ipc_client_nv_data_path(client), &nv_stat) < 0)
{
ipc_client_log(client, "nv_data_check: nv_data.bin missing");
nv_data_backup_restore(client);
- stat(nv_data_path(client), &nv_stat);
+ stat(ipc_client_nv_data_path(client), &nv_stat);
}
- if (nv_stat.st_size != nv_data_size(client))
+ if (nv_stat.st_size != ipc_client_nv_data_size(client))
{
ipc_client_log(client, "nv_data_check: wrong nv_data.bin size");
nv_data_backup_restore(client);
}
- if (stat(nv_data_md5_path(client), &nv_stat) < 0)
+ if (stat(ipc_client_nv_data_md5_path(client), &nv_stat) < 0)
{
ipc_client_log(client, "nv_data_check: nv_data.bin.md5 missing");
nv_data_backup_restore(client);
}
- if (stat(nv_data_bak_path(client), &nv_stat) < 0 || stat(nv_data_md5_bak_path(client), &nv_stat) < 0)
+ if (stat(ipc_client_nv_data_backup_path(client), &nv_stat) < 0 || stat(ipc_client_nv_data_backup_md5_path(client), &nv_stat) < 0)
{
ipc_client_log(client, "nv_data_check: .nv_data.bak or .nv_data.bak.md5 missing");
nv_data_backup_create(client);
}
- nv_state_fd = open(nv_state_path(client), O_RDONLY);
-
- if (nv_state_fd < 0 || fstat(nv_state_fd, &nv_stat) < 0)
- {
- ipc_client_log(client, "nv_data_check: .nv_state missing");
- nv_data_backup_restore(client);
- }
-
- rc = read(nv_state_fd, &nv_state, sizeof(nv_state));
- if (rc < 0)
- {
- ipc_client_log(client, "nv_data_check: couldn't read state of NV item from file");
- return -1;
- }
-
- close(nv_state_fd);
-
- if (nv_state != '1')
- {
- ipc_client_log(client, "nv_data_check: bad nv_state");
- nv_data_backup_restore(client);
- }
-
ipc_client_log(client, "nv_data_check: everything should be alright");
ipc_client_log(client, "nv_data_check: exit");
@@ -704,17 +563,17 @@ int nv_data_md5_check(struct ipc_client *client)
memset(nv_data_md5_hash_read, 0, MD5_STRING_SIZE);
memset(nv_data_md5_hash_string, 0, MD5_STRING_SIZE);
- nv_data_p = file_data_read(nv_data_path(client),
- nv_data_size(client), nv_data_chunk_size(client));
+ nv_data_p = file_data_read(ipc_client_nv_data_path(client),
+ ipc_client_nv_data_size(client), ipc_client_nv_data_chunk_size(client));
data_p = nv_data_p;
- nv_data_md5_compute(data_p, nv_data_size(client), nv_data_secret(client), nv_data_md5_hash);
+ nv_data_md5_compute(data_p, ipc_client_nv_data_size(client), ipc_client_nv_data_secret(client), nv_data_md5_hash);
md5hash2string(nv_data_md5_hash_string, nv_data_md5_hash);
free(nv_data_p);
- fd = open(nv_data_md5_path(client), O_RDONLY);
+ fd = open(ipc_client_nv_data_md5_path(client), O_RDONLY);
/* Read the md5 stored in the file. */
rc = read(fd, nv_data_md5_hash_read, MD5_STRING_SIZE);
@@ -766,7 +625,7 @@ int nv_data_read(struct ipc_client *client, int offset, int length, char *buf)
if (nv_data_check(client) < 0)
return -1;
- fd = open(nv_data_path(client), O_RDONLY);
+ fd = open(ipc_client_nv_data_path(client), O_RDONLY);
if (fd < 0) {
ipc_client_log(client, "nv_data_read: nv_data file fd is negative");
return -1;
@@ -805,7 +664,7 @@ int nv_data_write(struct ipc_client *client, int offset, int length, char *buf)
if (nv_data_check(client) < 0)
return -1;
- fd = open(nv_data_path(client), O_WRONLY);
+ fd = open(ipc_client_nv_data_path(client), O_WRONLY);
if (fd < 0) {
ipc_client_log(client, "nv_data_write: nv_data file fd is negative");
return -1;