Merge branch 'bugfix/vfs_open_errno' into 'master'

vfs: don't overwrite errno by a hard coded ENOENT (Github PR)

Closes IDFGH-6378

See merge request espressif/esp-idf!16790
This commit is contained in:
Martin Vychodil 2022-01-14 17:23:07 +00:00
commit f01b9a583e
2 changed files with 39 additions and 1 deletions

View File

@ -0,0 +1,38 @@
/*
* SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <stdio.h>
#include <string.h>
#include <fcntl.h>
#include <errno.h>
#include "esp_vfs.h"
#include "unity.h"
static int open_errno_test_open(const char * path, int flags, int mode)
{
errno = EIO;
return -1;
}
TEST_CASE("esp_vfs_open sets correct errno", "[vfs]")
{
esp_vfs_t desc = {
.open = open_errno_test_open
};
TEST_ESP_OK(esp_vfs_register("/test", &desc, NULL));
int fd = open("/test/path", 0, 0);
int e = errno;
TEST_ASSERT_EQUAL(-1, fd);
TEST_ASSERT_EQUAL(EIO, e);
fd = open("/nonexistent/path", 0, 0);
e = errno;
TEST_ASSERT_EQUAL(-1, fd);
TEST_ASSERT_EQUAL(ENOENT, e);
TEST_ESP_OK(esp_vfs_unregister("/test"));
}

View File

@ -415,7 +415,7 @@ int esp_vfs_open(struct _reent *r, const char * path, int flags, int mode)
__errno_r(r) = ENOMEM;
return -1;
}
__errno_r(r) = ENOENT;
__errno_r(r) = errno;
return -1;
}