aboutsummaryrefslogtreecommitdiffstats
path: root/samsung-ipc
diff options
context:
space:
mode:
authorDenis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>2020-04-04 19:11:17 +0200
committerDenis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>2020-06-27 18:39:10 +0200
commitce949685c0e84078d1b70916225f15b30b98c65a (patch)
treeafb4d8ca2e52e7c84381c278c1d8e3479be103f0 /samsung-ipc
parentbb985d5fdeff99c557ffec779e684ee390304cb5 (diff)
downloadhardware_replicant_libsamsung-ipc-ce949685c0e84078d1b70916225f15b30b98c65a.tar.gz
hardware_replicant_libsamsung-ipc-ce949685c0e84078d1b70916225f15b30b98c65a.tar.bz2
hardware_replicant_libsamsung-ipc-ce949685c0e84078d1b70916225f15b30b98c65a.zip
samsung-ipc: rfs: switch to Linux code style
This contains no functional changes. The commented out code if any has also been preserved as it could be relevant to the understanding of the code. It will be kept until we understand why the code has been commented. In that case we either need to remove it completely or to replace it by a comment explaining why not having that code was necessary. For __FUNCTION__, according to checkpatch.pl, it's gcc specific: WARNING: __func__ should be used instead of gcc specific __FUNCTION__ However __func__ is part of the C18 standard[1]. In the "6.4.2.2 Predefined identifiers" section, we have: "The identifier __func__ shall be implicitly declared by the translator as if, immediately following the opening brace of each function definition, the declaration static const char __func__[] = "function-name"; " References: ----------- [1]The standard doesn't seem to be available for free, but the draft can be downloaded from the following URL: https://web.archive.org/web/20181230041359if_/http://www.open-std.org/jtc1/sc22/wg14/www/abq/c17_updated_proposed_fdis.pdf Signed-off-by: Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org> Reviewed-by: Joonas Kylmälä <joonas.kylmala@iki.fi>
Diffstat (limited to 'samsung-ipc')
-rw-r--r--samsung-ipc/rfs.c1176
1 files changed, 606 insertions, 570 deletions
diff --git a/samsung-ipc/rfs.c b/samsung-ipc/rfs.c
index fc134bf..f57c32e 100644
--- a/samsung-ipc/rfs.c
+++ b/samsung-ipc/rfs.c
@@ -36,699 +36,735 @@ char *ipc_nv_data_md5_calculate(struct ipc_client *client,
const char *path, const char *secret,
size_t size, size_t chunk_size)
{
- void *data = NULL;
- char *md5_string = NULL;
- unsigned char md5_hash[MD5_DIGEST_LENGTH] = { 0 };
- MD5_CTX ctx;
-
- if (secret == NULL) {
- ipc_client_log(client, "%s: Failed: secret is NULL", __FUNCTION__);
- return NULL;
- }
-
- data = file_data_read(client, path, size, chunk_size, 0);
- if (data == NULL) {
- ipc_client_log(client, "%s failed: data is NULL", __FUNCTION__);
- return NULL;
- }
-
- MD5_Init(&ctx);
- MD5_Update(&ctx, data, size);
- MD5_Update(&ctx, secret, strlen(secret));
- MD5_Final((unsigned char *) &md5_hash, &ctx);
-
- md5_string = data2string(&md5_hash, sizeof(md5_hash));
-
- return md5_string;
+ void *data = NULL;
+ char *md5_string = NULL;
+ unsigned char md5_hash[MD5_DIGEST_LENGTH] = { 0 };
+ MD5_CTX ctx;
+
+ if (secret == NULL) {
+ ipc_client_log(client, "%s: Failed: secret is NULL", __func__);
+ return NULL;
+ }
+
+ data = file_data_read(client, path, size, chunk_size, 0);
+ if (data == NULL) {
+ ipc_client_log(client, "%s failed: data is NULL", __func__);
+ return NULL;
+ }
+
+ MD5_Init(&ctx);
+ MD5_Update(&ctx, data, size);
+ MD5_Update(&ctx, secret, strlen(secret));
+ MD5_Final((unsigned char *) &md5_hash, &ctx);
+
+ md5_string = data2string(&md5_hash, sizeof(md5_hash));
+
+ return md5_string;
}
int ipc_nv_data_path_check(struct ipc_client *client)
{
- struct stat st;
- char *path;
- off_t size;
- int rc;
+ struct stat st;
+ char *path;
+ off_t size;
+ int rc;
- if (client == NULL)
- return -1;
+ if (client == NULL)
+ return -1;
- path = ipc_client_nv_data_path(client);
- size = ipc_client_nv_data_size(client);
- if (path == NULL || size == 0)
- return -1;
+ path = ipc_client_nv_data_path(client);
+ size = ipc_client_nv_data_size(client);
+ if (path == NULL || size == 0)
+ return -1;
- rc = stat(path, &st);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data path failed");
- return -1;
- }
+ rc = stat(path, &st);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data path failed");
+ return -1;
+ }
- if (st.st_size != size) {
- ipc_client_log(client, "Checking nv_data size failed");
- return -1;
- }
+ if (st.st_size != size) {
+ ipc_client_log(client, "Checking nv_data size failed");
+ return -1;
+ }
- ipc_client_log(client, "Checked nv_data path");
+ ipc_client_log(client, "Checked nv_data path");
- return 0;
+ return 0;
}
int ipc_nv_data_md5_path_check(struct ipc_client *client)
{
- struct stat st;
- char *md5_path;
- int rc;
+ struct stat st;
+ char *md5_path;
+ int rc;
- if (client == NULL)
- return -1;
+ if (client == NULL)
+ return -1;
- md5_path = ipc_client_nv_data_md5_path(client);
- if (md5_path == NULL)
- return -1;
+ md5_path = ipc_client_nv_data_md5_path(client);
+ if (md5_path == NULL)
+ return -1;
- rc = stat(md5_path, &st);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data md5 path failed");
- return -1;
- }
+ rc = stat(md5_path, &st);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data md5 path failed");
+ return -1;
+ }
- if (st.st_size < 2 * sizeof(char) * MD5_DIGEST_LENGTH) {
- ipc_client_log(client, "Checking nv_data md5 size failed");
- return -1;
- }
+ if (st.st_size < 2 * sizeof(char) * MD5_DIGEST_LENGTH) {
+ ipc_client_log(client, "Checking nv_data md5 size failed");
+ return -1;
+ }
- ipc_client_log(client, "Checked nv_data md5 path");
+ ipc_client_log(client, "Checked nv_data md5 path");
- return 0;
+ return 0;
}
int ipc_nv_data_backup_path_check(struct ipc_client *client)
{
- struct stat st;
- char *backup_path;
- off_t size;
- int rc;
+ struct stat st;
+ char *backup_path;
+ off_t size;
+ int rc;
- if (client == NULL)
- return -1;
+ if (client == NULL)
+ return -1;
- backup_path = ipc_client_nv_data_backup_path(client);
- size = ipc_client_nv_data_size(client);
- if (backup_path == NULL || size == 0)
- return -1;
+ backup_path = ipc_client_nv_data_backup_path(client);
+ size = ipc_client_nv_data_size(client);
+ if (backup_path == NULL || size == 0)
+ return -1;
- rc = stat(backup_path, &st);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data backup path failed");
- return -1;
- }
+ rc = stat(backup_path, &st);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data backup path failed");
+ return -1;
+ }
- if (st.st_size != size) {
- ipc_client_log(client, "Checking nv_data backup size failed");
- return -1;
- }
+ if (st.st_size != size) {
+ ipc_client_log(client, "Checking nv_data backup size failed");
+ return -1;
+ }
- ipc_client_log(client, "Checked nv_data backup path");
+ ipc_client_log(client, "Checked nv_data backup path");
- return 0;
+ return 0;
}
int ipc_nv_data_backup_md5_path_check(struct ipc_client *client)
{
- struct stat st;
- char *backup_md5_path;
- int rc;
+ struct stat st;
+ char *backup_md5_path;
+ int rc;
- if (client == NULL)
- return -1;
+ if (client == NULL)
+ return -1;
- backup_md5_path = ipc_client_nv_data_backup_md5_path(client);
- if (backup_md5_path == NULL)
- return -1;
+ backup_md5_path = ipc_client_nv_data_backup_md5_path(client);
+ if (backup_md5_path == NULL)
+ return -1;
- rc = stat(backup_md5_path, &st);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data backup md5 path failed");
- return -1;
- }
+ rc = stat(backup_md5_path, &st);
+ if (rc < 0) {
+ ipc_client_log(client,
+ "Checking nv_data backup md5 path failed");
+ return -1;
+ }
- if (st.st_size < 2 * sizeof(char) * MD5_DIGEST_LENGTH) {
- ipc_client_log(client, "Checking nv_data backup md5 size failed");
- return -1;
- }
+ if (st.st_size < 2 * sizeof(char) * MD5_DIGEST_LENGTH) {
+ ipc_client_log(client,
+ "Checking nv_data backup md5 size failed");
+ return -1;
+ }
- ipc_client_log(client, "Checked nv_data backup md5 path");
+ ipc_client_log(client, "Checked nv_data backup md5 path");
- return 0;
+ return 0;
}
int ipc_nv_data_check(struct ipc_client *client)
{
- char *path;
- char *md5_path;
- char *secret;
- size_t size;
- size_t chunk_size;
- char *md5_string = NULL;
- void *buffer = NULL;
- char *string = NULL;
- size_t length;
- int rc;
-
- if (client == NULL)
- return -1;
-
- path = ipc_client_nv_data_path(client);
- md5_path = ipc_client_nv_data_md5_path(client);
- secret = ipc_client_nv_data_secret(client);
- size = ipc_client_nv_data_size(client);
- chunk_size = ipc_client_nv_data_chunk_size(client);
- if (path == NULL || md5_path == NULL || secret == NULL || size == 0 || chunk_size == 0)
- return -1;
-
- rc = ipc_nv_data_path_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data path failed");
- goto error;
- }
-
- rc = ipc_nv_data_md5_path_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data md5 path failed");
- goto error;
- }
-
- md5_string = ipc_nv_data_md5_calculate(client, path, secret, size, chunk_size);
- if (md5_string == NULL) {
- ipc_client_log(client, "Calculating nv_data md5 failed");
- goto error;
- }
- ipc_client_log(client, "Calculated nv_data md5: %s", md5_string);
-
- length = strlen(md5_string);
-
- buffer = file_data_read(client, md5_path, length, length, 0);
- if (buffer == NULL) {
- ipc_client_log(client, "Reading nv_data md5 failed");
- goto error;
- }
-
- string = strndup(buffer, length);
- ipc_client_log(client, "Read nv_data md5: %s", string);
-
- rc = strncmp(md5_string, string, length);
- if (rc != 0) {
- ipc_client_log(client, "Matching nv_data md5 failed");
- goto error;
- }
-
- rc = 0;
- goto complete;
+ char *path;
+ char *md5_path;
+ char *secret;
+ size_t size;
+ size_t chunk_size;
+ char *md5_string = NULL;
+ void *buffer = NULL;
+ char *string = NULL;
+ size_t length;
+ int rc;
+
+ if (client == NULL)
+ return -1;
+
+ path = ipc_client_nv_data_path(client);
+ md5_path = ipc_client_nv_data_md5_path(client);
+ secret = ipc_client_nv_data_secret(client);
+ size = ipc_client_nv_data_size(client);
+ chunk_size = ipc_client_nv_data_chunk_size(client);
+ if (path == NULL || md5_path == NULL || secret == NULL || size == 0 ||
+ chunk_size == 0) {
+ return -1;
+ }
+
+ rc = ipc_nv_data_path_check(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data path failed");
+ goto error;
+ }
+
+ rc = ipc_nv_data_md5_path_check(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data md5 path failed");
+ goto error;
+ }
+
+ md5_string = ipc_nv_data_md5_calculate(client, path, secret, size,
+ chunk_size);
+ if (md5_string == NULL) {
+ ipc_client_log(client, "Calculating nv_data md5 failed");
+ goto error;
+ }
+ ipc_client_log(client, "Calculated nv_data md5: %s", md5_string);
+
+ length = strlen(md5_string);
+
+ buffer = file_data_read(client, md5_path, length, length, 0);
+ if (buffer == NULL) {
+ ipc_client_log(client, "Reading nv_data md5 failed");
+ goto error;
+ }
+
+ string = strndup(buffer, length);
+ ipc_client_log(client, "Read nv_data md5: %s", string);
+
+ rc = strncmp(md5_string, string, length);
+ if (rc != 0) {
+ ipc_client_log(client, "Matching nv_data md5 failed");
+ goto error;
+ }
+
+ rc = 0;
+ goto complete;
error:
- rc = -1;
+ rc = -1;
complete:
- if (string != NULL)
- free(string);
+ if (string != NULL)
+ free(string);
- if (buffer != NULL)
- free(buffer);
+ if (buffer != NULL)
+ free(buffer);
- if (md5_string != NULL)
- free(md5_string);
+ if (md5_string != NULL)
+ free(md5_string);
- return rc;
+ return rc;
}
int ipc_nv_data_backup_check(struct ipc_client *client)
{
- char *backup_path;
- char *backup_md5_path;
- char *secret;
- size_t size;
- size_t chunk_size;
- char *backup_md5_string = NULL;
- void *buffer = NULL;
- char *string = NULL;
- size_t length;
- int rc;
-
- if (client == NULL)
- return -1;
-
- backup_path = ipc_client_nv_data_backup_path(client);
- backup_md5_path = ipc_client_nv_data_backup_md5_path(client);
- secret = ipc_client_nv_data_secret(client);
- size = ipc_client_nv_data_size(client);
- chunk_size = ipc_client_nv_data_chunk_size(client);
- if (backup_path == NULL || backup_md5_path == NULL || secret == NULL || size == 0 || chunk_size == 0)
- return -1;
-
- rc = ipc_nv_data_backup_path_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data backup path failed");
- goto error;
- }
-
- rc = ipc_nv_data_backup_md5_path_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data backup md5 path failed");
- goto error;
- }
-
- backup_md5_string = ipc_nv_data_md5_calculate(client, backup_path, secret, size, chunk_size);
- if (backup_md5_string == NULL) {
- ipc_client_log(client, "Calculating nv_data backup md5 failed");
- goto error;
- }
- ipc_client_log(client, "Calculated nv_data backup md5: %s", backup_md5_string);
-
- length = strlen(backup_md5_string);
-
- buffer = file_data_read(client, backup_md5_path, length, length, 0);
- if (buffer == NULL) {
- ipc_client_log(client, "Reading nv_data backup md5 failed");
- goto error;
- }
-
- string = strndup(buffer, length);
- ipc_client_log(client, "Read nv_data backup md5: %s", string);
-
- rc = strncmp(backup_md5_string, string, length);
- if (rc != 0) {
- ipc_client_log(client, "Matching nv_data backup md5 failed");
- goto error;
- }
-
- rc = 0;
- goto complete;
+ char *backup_path;
+ char *backup_md5_path;
+ char *secret;
+ size_t size;
+ size_t chunk_size;
+ char *backup_md5_string = NULL;
+ void *buffer = NULL;
+ char *string = NULL;
+ size_t length;
+ int rc;
+
+ if (client == NULL)
+ return -1;
+
+ backup_path = ipc_client_nv_data_backup_path(client);
+ backup_md5_path = ipc_client_nv_data_backup_md5_path(client);
+ secret = ipc_client_nv_data_secret(client);
+ size = ipc_client_nv_data_size(client);
+ chunk_size = ipc_client_nv_data_chunk_size(client);
+ if (backup_path == NULL || backup_md5_path == NULL || secret == NULL ||
+ size == 0 || chunk_size == 0) {
+ return -1;
+ }
+
+ rc = ipc_nv_data_backup_path_check(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data backup path failed");
+ goto error;
+ }
+
+ rc = ipc_nv_data_backup_md5_path_check(client);
+ if (rc < 0) {
+ ipc_client_log(client,
+ "Checking nv_data backup md5 path failed");
+ goto error;
+ }
+
+ backup_md5_string = ipc_nv_data_md5_calculate(client,
+ backup_path, secret, size,
+ chunk_size);
+ if (backup_md5_string == NULL) {
+ ipc_client_log(client, "Calculating nv_data backup md5 failed");
+ goto error;
+ }
+ ipc_client_log(client, "Calculated nv_data backup md5: %s",
+ backup_md5_string);
+
+ length = strlen(backup_md5_string);
+
+ buffer = file_data_read(client, backup_md5_path, length, length, 0);
+ if (buffer == NULL) {
+ ipc_client_log(client, "Reading nv_data backup md5 failed");
+ goto error;
+ }
+
+ string = strndup(buffer, length);
+ ipc_client_log(client, "Read nv_data backup md5: %s", string);
+
+ rc = strncmp(backup_md5_string, string, length);
+ if (rc != 0) {
+ ipc_client_log(client, "Matching nv_data backup md5 failed");
+ goto error;
+ }
+
+ rc = 0;
+ goto complete;
error:
- rc = -1;
+ rc = -1;
complete:
- if (string != NULL)
- free(string);
+ if (string != NULL)
+ free(string);
- if (buffer != NULL)
- free(buffer);
+ if (buffer != NULL)
+ free(buffer);
- if (backup_md5_string != NULL)
- free(backup_md5_string);
+ if (backup_md5_string != NULL)
+ free(backup_md5_string);
- return rc;
+ return rc;
}
int ipc_nv_data_backup(struct ipc_client *client)
{
- void *data = NULL;
- char *path;
- char *backup_path;
- char *backup_md5_path;
- char *secret;
- size_t size;
- size_t chunk_size;
- char *md5_string = NULL;
- size_t length;
- int rc;
-
- if (client == NULL)
- return -1;
-
- path = ipc_client_nv_data_path(client);
- backup_path = ipc_client_nv_data_backup_path(client);
- backup_md5_path = ipc_client_nv_data_backup_md5_path(client);
- secret = ipc_client_nv_data_secret(client);
- size = ipc_client_nv_data_size(client);
- chunk_size = ipc_client_nv_data_chunk_size(client);
- if (path == NULL || backup_path == NULL || backup_md5_path == NULL || secret == NULL || size == 0 || chunk_size == 0)
- return -1;
-
- rc = ipc_nv_data_path_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data path failed");
- goto error;
- }
-
- data = file_data_read(client, path, size, chunk_size, 0);
- if (data == NULL) {
- ipc_client_log(client, "Reading nv_data failed");
- goto error;
- }
-
- md5_string = ipc_nv_data_md5_calculate(client, path, secret, size, chunk_size);
- if (md5_string == NULL) {
- ipc_client_log(client, "Calculating nv_data md5 failed");
- goto error;
- }
-
- length = strlen(md5_string);
-
- rc = unlink(backup_path);
- if (rc < 0)
- ipc_client_log(client, "Removing nv_data backup path failed");
-
- rc = file_data_write(client, backup_path, data, size, chunk_size, 0);
- if (rc < 0) {
- ipc_client_log(client, "Writing nv_data backup failed");
- goto error;
- }
-
- rc = unlink(backup_md5_path);
- if (rc < 0)
- ipc_client_log(client, "Removing nv_data backup md5 path failed");
-
- rc = file_data_write(client, backup_md5_path, md5_string, length, length, 0);
- if (rc < 0) {
- ipc_client_log(client, "Writing nv_data backup md5 failed");
- goto error;
- }
-
- ipc_client_log(client, "Backed up nv_data");
-
- rc = 0;
- goto complete;
+ void *data = NULL;
+ char *path;
+ char *backup_path;
+ char *backup_md5_path;
+ char *secret;
+ size_t size;
+ size_t chunk_size;
+ char *md5_string = NULL;
+ size_t length;
+ int rc;
+
+ if (client == NULL)
+ return -1;
+
+ path = ipc_client_nv_data_path(client);
+ backup_path = ipc_client_nv_data_backup_path(client);
+ backup_md5_path = ipc_client_nv_data_backup_md5_path(client);
+ secret = ipc_client_nv_data_secret(client);
+ size = ipc_client_nv_data_size(client);
+ chunk_size = ipc_client_nv_data_chunk_size(client);
+ if (path == NULL || backup_path == NULL || backup_md5_path == NULL ||
+ secret == NULL || size == 0 || chunk_size == 0) {
+ return -1;
+ }
+
+ rc = ipc_nv_data_path_check(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data path failed");
+ goto error;
+ }
+
+ data = file_data_read(client, path, size, chunk_size, 0);
+ if (data == NULL) {
+ ipc_client_log(client, "Reading nv_data failed");
+ goto error;
+ }
+
+ md5_string = ipc_nv_data_md5_calculate(client, path, secret, size,
+ chunk_size);
+ if (md5_string == NULL) {
+ ipc_client_log(client, "Calculating nv_data md5 failed");
+ goto error;
+ }
+
+ length = strlen(md5_string);
+
+ rc = unlink(backup_path);
+ if (rc < 0)
+ ipc_client_log(client, "Removing nv_data backup path failed");
+
+ rc = file_data_write(client, backup_path, data, size, chunk_size, 0);
+ if (rc < 0) {
+ ipc_client_log(client, "Writing nv_data backup failed");
+ goto error;
+ }
+
+ rc = unlink(backup_md5_path);
+ if (rc < 0)
+ ipc_client_log(client,
+ "Removing nv_data backup md5 path failed");
+
+ rc = file_data_write(client, backup_md5_path, md5_string, length,
+ length, 0);
+ if (rc < 0) {
+ ipc_client_log(client, "Writing nv_data backup md5 failed");
+ goto error;
+ }
+
+ ipc_client_log(client, "Backed up nv_data");
+
+ rc = 0;
+ goto complete;
error:
- rc = -1;
+ rc = -1;
complete:
- if (md5_string != NULL)
- free(md5_string);
+ if (md5_string != NULL)
+ free(md5_string);
- if (data != NULL)
- free(data);
+ if (data != NULL)
+ free(data);
- return rc;
+ return rc;
}
int ipc_nv_data_restore(struct ipc_client *client)
{
- void *data = NULL;
- char *path;
- char *md5_path;
- char *backup_path;
- char *backup_md5_path;
- char *secret;
- size_t size;
- size_t chunk_size;
- size_t length;
- int rc;
-
- if (client == NULL)
- return -1;
-
- path = ipc_client_nv_data_path(client);
- md5_path = ipc_client_nv_data_md5_path(client);
- backup_path = ipc_client_nv_data_backup_path(client);
- backup_md5_path = ipc_client_nv_data_backup_md5_path(client);
- secret = ipc_client_nv_data_secret(client);
- size = ipc_client_nv_data_size(client);
- chunk_size = ipc_client_nv_data_chunk_size(client);
- if (path == NULL || md5_path == NULL || backup_path == NULL || backup_md5_path == NULL || secret == NULL || size == 0 || chunk_size == 0)
- return -1;
-
- rc = ipc_nv_data_backup_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data backup failed");
- goto error;
- }
-
- data = file_data_read(client, backup_path, size, chunk_size, 0);
- if (data == NULL) {
- ipc_client_log(client, "Reading nv_data backup failed");
- goto error;
- }
-
- rc = unlink(path);
- if (rc < 0)
- ipc_client_log(client, "Removing nv_data path failed");
-
- rc = file_data_write(client, path, data, size, chunk_size, 0);
- if (rc < 0) {
- ipc_client_log(client, "Writing nv_data failed");
- goto error;
- }
-
- free(data);
- data = NULL;
-
- length = 2 * sizeof(char) * MD5_DIGEST_LENGTH;
-
- data = file_data_read(client, backup_md5_path, length, length, 0);
- if (data == NULL) {
- ipc_client_log(client, "Reading nv_data backup md5 failed");
- goto error;
- }
-
- rc = unlink(md5_path);
- if (rc < 0)
- ipc_client_log(client, "Removing nv_data md5 path failed");
-
- rc = file_data_write(client, md5_path, data, length, length, 0);
- if (rc < 0) {
- ipc_client_log(client, "Writing nv_data md5 failed");
- goto error;
- }
-
- ipc_client_log(client, "Restored nv_data");
-
- rc = 0;
- goto complete;
+ void *data = NULL;
+ char *path;
+ char *md5_path;
+ char *backup_path;
+ char *backup_md5_path;
+ char *secret;
+ size_t size;
+ size_t chunk_size;
+ size_t length;
+ int rc;
+
+ if (client == NULL)
+ return -1;
+
+ path = ipc_client_nv_data_path(client);
+ md5_path = ipc_client_nv_data_md5_path(client);
+ backup_path = ipc_client_nv_data_backup_path(client);
+ backup_md5_path = ipc_client_nv_data_backup_md5_path(client);
+ secret = ipc_client_nv_data_secret(client);
+ size = ipc_client_nv_data_size(client);
+ chunk_size = ipc_client_nv_data_chunk_size(client);
+ if (path == NULL || md5_path == NULL || backup_path == NULL ||
+ backup_md5_path == NULL || secret == NULL || size == 0 ||
+ chunk_size == 0) {
+ return -1;
+ }
+
+ rc = ipc_nv_data_backup_check(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data backup failed");
+ goto error;
+ }
+
+ data = file_data_read(client, backup_path, size, chunk_size, 0);
+ if (data == NULL) {
+ ipc_client_log(client, "Reading nv_data backup failed");
+ goto error;
+ }
+
+ rc = unlink(path);
+ if (rc < 0)
+ ipc_client_log(client, "Removing nv_data path failed");
+
+ rc = file_data_write(client, path, data, size, chunk_size, 0);
+ if (rc < 0) {
+ ipc_client_log(client, "Writing nv_data failed");
+ goto error;
+ }
+
+ free(data);
+ data = NULL;
+
+ length = 2 * sizeof(char) * MD5_DIGEST_LENGTH;
+
+ data = file_data_read(client, backup_md5_path, length, length, 0);
+ if (data == NULL) {
+ ipc_client_log(client, "Reading nv_data backup md5 failed");
+ goto error;
+ }
+
+ rc = unlink(md5_path);
+ if (rc < 0)
+ ipc_client_log(client, "Removing nv_data md5 path failed");
+
+ rc = file_data_write(client, md5_path, data, length, length, 0);
+ if (rc < 0) {
+ ipc_client_log(client, "Writing nv_data md5 failed");
+ goto error;
+ }
+
+ ipc_client_log(client, "Restored nv_data");
+
+ rc = 0;
+ goto complete;
error:
- rc = -1;
+ rc = -1;
complete:
- if (data != NULL)
- free(data);
+ if (data != NULL)
+ free(data);
- return rc;
+ return rc;
}
void *ipc_nv_data_load(struct ipc_client *client)
{
- void *data;
- char *path;
- size_t size;
- size_t chunk_size;
- int rc;
-
- if (client == NULL)
- return NULL;
-
- path = ipc_client_nv_data_path(client);
- size = ipc_client_nv_data_size(client);
- chunk_size = ipc_client_nv_data_chunk_size(client);
- if (path == NULL || size == 0 || chunk_size == 0)
- return NULL;
-
- rc = ipc_nv_data_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data failed");
-
- rc = ipc_nv_data_restore(client);
- if (rc < 0) {
- ipc_client_log(client, "Restoring nv_data failed");
- return NULL;
- }
-
- rc = ipc_nv_data_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data failed");
- return NULL;
- }
- }
-
- rc = ipc_nv_data_backup_path_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data backup path failed");
-
- rc = ipc_nv_data_backup(client);
- if (rc < 0)
- ipc_client_log(client, "Backing up nv_data failed");
- }
-
- data = file_data_read(client, path, size, chunk_size, 0);
- if (data == NULL) {
- ipc_client_log(client, "Reading nv_data failed");
- return NULL;
- }
-
- return data;
+ void *data;
+ char *path;
+ size_t size;
+ size_t chunk_size;
+ int rc;
+
+ if (client == NULL)
+ return NULL;
+
+ path = ipc_client_nv_data_path(client);
+ size = ipc_client_nv_data_size(client);
+ chunk_size = ipc_client_nv_data_chunk_size(client);
+ if (path == NULL || size == 0 || chunk_size == 0)
+ return NULL;
+
+ rc = ipc_nv_data_check(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data failed");
+
+ rc = ipc_nv_data_restore(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Restoring nv_data failed");
+ return NULL;
+ }
+
+ rc = ipc_nv_data_check(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data failed");
+ return NULL;
+ }
+ }
+
+ rc = ipc_nv_data_backup_path_check(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data backup path failed");
+
+ rc = ipc_nv_data_backup(client);
+ if (rc < 0)
+ ipc_client_log(client, "Backing up nv_data failed");
+ }
+
+ data = file_data_read(client, path, size, chunk_size, 0);
+ if (data == NULL) {
+ ipc_client_log(client, "Reading nv_data failed");
+ return NULL;
+ }
+
+ return data;
}
void *ipc_nv_data_read(struct ipc_client *client, size_t size,
- unsigned int offset)
+ unsigned int offset)
{
- void *data;
- char *path;
- size_t chunk_size;
- int rc;
-
- if (client == NULL)
- return NULL;
-
- path = ipc_client_nv_data_path(client);
- chunk_size = ipc_client_nv_data_chunk_size(client);
- if (path == NULL || chunk_size == 0)
- return NULL;
-
- rc = ipc_nv_data_path_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data path failed");
- return NULL;
- }
-
- data = file_data_read(client, path, size, chunk_size > size ? size : chunk_size, offset);
- if (data == NULL) {
- ipc_client_log(client, "Reading nv_data failed");
- return NULL;
- }
-
- return data;
+ void *data;
+ char *path;
+ size_t chunk_size;
+ int rc;
+
+ if (client == NULL)
+ return NULL;
+
+ path = ipc_client_nv_data_path(client);
+ chunk_size = ipc_client_nv_data_chunk_size(client);
+ if (path == NULL || chunk_size == 0)
+ return NULL;
+
+ rc = ipc_nv_data_path_check(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data path failed");
+ return NULL;
+ }
+
+ data = file_data_read(client, path, size,
+ chunk_size > size ? size : chunk_size, offset);
+ if (data == NULL) {
+ ipc_client_log(client, "Reading nv_data failed");
+ return NULL;
+ }
+
+ return data;
}
int ipc_nv_data_write(struct ipc_client *client, const void *data, size_t size,
- unsigned int offset)
+ unsigned int offset)
{
- char *path;
- char *md5_path;
- char *secret;
- size_t chunk_size;
- char *md5_string = NULL;
- size_t length;
- int rc;
-
- if (client == NULL)
- return -1;
-
- path = ipc_client_nv_data_path(client);
- md5_path = ipc_client_nv_data_md5_path(client);
- secret = ipc_client_nv_data_secret(client);
- chunk_size = ipc_client_nv_data_chunk_size(client);
- if (path == NULL || md5_path == NULL || secret == NULL || chunk_size == 0)
- return -1;
-
- rc = ipc_nv_data_path_check(client);
- if (rc < 0) {
- ipc_client_log(client, "Checking nv_data path failed");
- goto error;
- }
-
- rc = file_data_write(client, path, data, size, chunk_size > size ? size : chunk_size, offset);
- if (rc < 0) {
- ipc_client_log(client, "Writing nv_data failed");
- goto error;
- }
-
- size = ipc_client_nv_data_size(client);
- if (size == 0)
- goto error;
-
- md5_string = ipc_nv_data_md5_calculate(client, path, secret, size, chunk_size);
- if (md5_string == NULL) {
- ipc_client_log(client, "Calculating nv_data md5 failed");
- goto error;
- }
-
- length = strlen(md5_string);
-
- rc = unlink(md5_path);
- if (rc < 0) {
- ipc_client_log(client, "Removing nv_data md5 path failed");
- goto error;
- }
-
- rc = file_data_write(client, md5_path, md5_string, length, length, 0);
- if (rc < 0) {
- ipc_client_log(client, "Writing nv_data md5 failed");
- goto error;
- }
-
- rc = 0;
- goto complete;
+ char *path;
+ char *md5_path;
+ char *secret;
+ size_t chunk_size;
+ char *md5_string = NULL;
+ size_t length;
+ int rc;
+
+ if (client == NULL)
+ return -1;
+
+ path = ipc_client_nv_data_path(client);
+ md5_path = ipc_client_nv_data_md5_path(client);
+ secret = ipc_client_nv_data_secret(client);
+ chunk_size = ipc_client_nv_data_chunk_size(client);
+ if (path == NULL || md5_path == NULL || secret == NULL ||
+ chunk_size == 0) {
+ return -1;
+ }
+
+ rc = ipc_nv_data_path_check(client);
+ if (rc < 0) {
+ ipc_client_log(client, "Checking nv_data path failed");
+ goto error;
+ }
+
+ rc = file_data_write(client, path, data, size,
+ chunk_size > size ? size : chunk_size, offset);
+ if (rc < 0) {
+ ipc_client_log(client, "Writing nv_data failed");
+ goto error;
+ }
+
+ size = ipc_client_nv_data_size(client);
+ if (size == 0)
+ goto error;
+
+ md5_string = ipc_nv_data_md5_calculate(client, path, secret, size,
+ chunk_size);
+ if (md5_string == NULL) {
+ ipc_client_log(client, "Calculating nv_data md5 failed");
+ goto error;
+ }
+
+ length = strlen(md5_string);
+
+ rc = unlink(md5_path);
+ if (rc < 0) {
+ ipc_client_log(client, "Removing nv_data md5 path failed");
+ goto error;
+ }
+
+ rc = file_data_write(client, md5_path, md5_string, length, length, 0);
+ if (rc < 0) {
+ ipc_client_log(client, "Writing nv_data md5 failed");
+ goto error;
+ }
+
+ rc = 0;
+ goto complete;
error:
- rc = -1;
+ rc = -1;
complete:
- if (md5_string != NULL)
- free(md5_string);
+ if (md5_string != NULL)
+ free(md5_string);
- return rc;
+ return rc;
}
-size_t ipc_rfs_nv_data_item_size_setup(struct ipc_rfs_nv_read_item_response_header *header,
- const void *nv_data, size_t nv_size)
+size_t ipc_rfs_nv_data_item_size_setup(
+ struct ipc_rfs_nv_read_item_response_header *header,
+ const void *nv_data, size_t nv_size)
{
- size_t size = 0;
+ size_t size = 0;
- if (header == NULL || nv_data == NULL || nv_size == 0)
- return 0;
+ if (header == NULL || nv_data == NULL || nv_size == 0)
+ return 0;
- size = sizeof(struct ipc_rfs_nv_read_item_response_header) + size;
+ size = sizeof(struct ipc_rfs_nv_read_item_response_header) + size;
- return size;
+ return size;
}
-void *ipc_rfs_nv_read_item_setup(struct ipc_rfs_nv_read_item_response_header *header,
- const void *nv_data, size_t nv_size)
+void *ipc_rfs_nv_read_item_setup(
+ struct ipc_rfs_nv_read_item_response_header *header,
+ const void *nv_data, size_t nv_size)
{
- void *data;
- size_t size;
- unsigned char *p;
+ void *data;
+ size_t size;
+ unsigned char *p;
- if (header == NULL || nv_data == NULL || nv_size == 0)
- return NULL;
+ if (header == NULL || nv_data == NULL || nv_size == 0)
+ return NULL;
- size = ipc_rfs_nv_data_item_size_setup(header, nv_data, nv_size);
- if (size == 0)
- return NULL;
+ size = ipc_rfs_nv_data_item_size_setup(header, nv_data, nv_size);
+ if (size == 0)
+ return NULL;
- data = calloc(1, size);
+ data = calloc(1, size);
- p = (unsigned char *) data;
+ p = (unsigned char *) data;
- memcpy(p, header, sizeof(struct ipc_rfs_nv_read_item_response_header));
- p += sizeof(struct ipc_rfs_nv_read_item_response_header);
+ memcpy(p, header, sizeof(struct ipc_rfs_nv_read_item_response_header));
+ p += sizeof(struct ipc_rfs_nv_read_item_response_header);
- memcpy(p, nv_data, nv_size);
- p += nv_size;
+ memcpy(p, nv_data, nv_size);
+ p += nv_size;
- return data;
+ return data;
}
size_t ipc_rfs_nv_write_item_size_extract(const void *data, size_t size)
{
- struct ipc_rfs_nv_write_item_request_header *header;
+ struct ipc_rfs_nv_write_item_request_header *header;
- if (data == NULL || size < sizeof(struct ipc_rfs_nv_write_item_request_header))
- return 0;
+ if (data == NULL ||
+ size < sizeof(struct ipc_rfs_nv_write_item_request_header)) {
+ return 0;
+ }
- header = (struct ipc_rfs_nv_write_item_request_header *) data;
- if (header->length == 0 || header->length > size - sizeof(struct ipc_rfs_nv_write_item_request_header))
- return 0;
+ header = (struct ipc_rfs_nv_write_item_request_header *) data;
+ if (header->length == 0 ||
+ header->length > size -
+ sizeof(struct ipc_rfs_nv_write_item_request_header)) {
+ return 0;
+ }
- return header->length;
+ return header->length;
}
void *ipc_rfs_nv_write_item_extract(const void *data, size_t size)
{
- struct ipc_rfs_nv_write_item_request_header *header;
- void *nv_data;
-
- if (data == NULL || size < sizeof(struct ipc_rfs_nv_write_item_request_header))
- return NULL;
-
- header = (struct ipc_rfs_nv_write_item_request_header *) data;
- if (header->length == 0 || header->length > size - sizeof(struct ipc_rfs_nv_write_item_request_header))
- return NULL;
-
- nv_data = (void *) ((unsigned char *) data + sizeof(struct ipc_rfs_nv_write_item_request_header));
-
- return nv_data;
+ struct ipc_rfs_nv_write_item_request_header *header;
+ void *nv_data;
+
+ if (data == NULL ||
+ size < sizeof(struct ipc_rfs_nv_write_item_request_header)) {
+ return NULL;
+ }
+
+ header = (struct ipc_rfs_nv_write_item_request_header *) data;
+ if (header->length == 0 ||
+ header->length > size -
+ sizeof(struct ipc_rfs_nv_write_item_request_header)) {
+ return NULL;
+ }
+
+ nv_data = (void *) (
+ (unsigned char *) data +
+ sizeof(struct ipc_rfs_nv_write_item_request_header));
+
+ return nv_data;
}
-
-// vim:ts=4:sw=4:expandtab