common: Fix support for environment file in EXT4
Signed-off-by: Andrej Rosano <andrej@inversepath.com>
This commit is contained in:
parent
ec048369e2
commit
bd62e2419b
|
@ -25,6 +25,7 @@
|
||||||
#include <environment.h>
|
#include <environment.h>
|
||||||
#include <linux/stddef.h>
|
#include <linux/stddef.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
|
#include <memalign.h>
|
||||||
#include <search.h>
|
#include <search.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <ext4fs.h>
|
#include <ext4fs.h>
|
||||||
|
@ -49,7 +50,7 @@ int env_init(void)
|
||||||
int saveenv(void)
|
int saveenv(void)
|
||||||
{
|
{
|
||||||
env_t env_new;
|
env_t env_new;
|
||||||
block_dev_desc_t *dev_desc = NULL;
|
struct blk_desc *dev_desc = NULL;
|
||||||
disk_partition_t info;
|
disk_partition_t info;
|
||||||
int dev, part;
|
int dev, part;
|
||||||
int err;
|
int err;
|
||||||
|
@ -58,13 +59,13 @@ int saveenv(void)
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
part = get_device_and_partition(EXT4_ENV_INTERFACE,
|
part = blk_get_device_part_str(EXT4_ENV_INTERFACE,
|
||||||
EXT4_ENV_DEVICE_AND_PART,
|
EXT4_ENV_DEVICE_AND_PART,
|
||||||
&dev_desc, &info, 1);
|
&dev_desc, &info, 1);
|
||||||
if (part < 0)
|
if (part < 0)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
dev = dev_desc->dev;
|
dev = dev_desc->devnum;
|
||||||
ext4fs_set_blk_dev(dev_desc, &info);
|
ext4fs_set_blk_dev(dev_desc, &info);
|
||||||
|
|
||||||
if (!ext4fs_mount(info.size)) {
|
if (!ext4fs_mount(info.size)) {
|
||||||
|
@ -90,18 +91,19 @@ int saveenv(void)
|
||||||
void env_relocate_spec(void)
|
void env_relocate_spec(void)
|
||||||
{
|
{
|
||||||
ALLOC_CACHE_ALIGN_BUFFER(char, buf, CONFIG_ENV_SIZE);
|
ALLOC_CACHE_ALIGN_BUFFER(char, buf, CONFIG_ENV_SIZE);
|
||||||
block_dev_desc_t *dev_desc = NULL;
|
struct blk_desc *dev_desc = NULL;
|
||||||
disk_partition_t info;
|
disk_partition_t info;
|
||||||
int dev, part;
|
int dev, part;
|
||||||
int err;
|
int err;
|
||||||
|
loff_t off;
|
||||||
|
|
||||||
part = get_device_and_partition(EXT4_ENV_INTERFACE,
|
part = blk_get_device_part_str(EXT4_ENV_INTERFACE,
|
||||||
EXT4_ENV_DEVICE_AND_PART,
|
EXT4_ENV_DEVICE_AND_PART,
|
||||||
&dev_desc, &info, 1);
|
&dev_desc, &info, 1);
|
||||||
if (part < 0)
|
if (part < 0)
|
||||||
goto err_env_relocate;
|
goto err_env_relocate;
|
||||||
|
|
||||||
dev = dev_desc->dev;
|
dev = dev_desc->devnum;
|
||||||
ext4fs_set_blk_dev(dev_desc, &info);
|
ext4fs_set_blk_dev(dev_desc, &info);
|
||||||
|
|
||||||
if (!ext4fs_mount(info.size)) {
|
if (!ext4fs_mount(info.size)) {
|
||||||
|
@ -110,7 +112,7 @@ void env_relocate_spec(void)
|
||||||
goto err_env_relocate;
|
goto err_env_relocate;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = ext4_read_file(EXT4_ENV_FILE, buf, 0, CONFIG_ENV_SIZE);
|
err = ext4_read_file(EXT4_ENV_FILE, buf, 0, CONFIG_ENV_SIZE, &off);
|
||||||
ext4fs_close();
|
ext4fs_close();
|
||||||
|
|
||||||
if (err == -1) {
|
if (err == -1) {
|
||||||
|
|
Loading…
Reference in New Issue