Unverified Commit 02f4178b authored by Jan Procházka's avatar Jan Procházka Committed by GitHub

BUGFIX: FS read + speed improvements for SD (#6569)

* Revert "Edited VFSFileImpl::read to use both read/fread (#6456)"

This reverts commit 7b89b39e.

* Added default file buffer size + function to change it by user
parent e1c96065
...@@ -130,6 +130,15 @@ size_t File::size() const ...@@ -130,6 +130,15 @@ size_t File::size() const
return _p->size(); return _p->size();
} }
bool File::setBufferSize(size_t size)
{
if (!*this) {
return 0;
}
return _p->setBufferSize(size);
}
void File::close() void File::close()
{ {
if (_p) { if (_p) {
......
...@@ -70,6 +70,7 @@ public: ...@@ -70,6 +70,7 @@ public:
} }
size_t position() const; size_t position() const;
size_t size() const; size_t size() const;
bool setBufferSize(size_t size);
void close(); void close();
operator bool() const; operator bool() const;
time_t getLastWrite(); time_t getLastWrite();
......
...@@ -36,6 +36,7 @@ public: ...@@ -36,6 +36,7 @@ public:
virtual bool seek(uint32_t pos, SeekMode mode) = 0; virtual bool seek(uint32_t pos, SeekMode mode) = 0;
virtual size_t position() const = 0; virtual size_t position() const = 0;
virtual size_t size() const = 0; virtual size_t size() const = 0;
virtual bool setBufferSize(size_t size) = 0;
virtual void close() = 0; virtual void close() = 0;
virtual time_t getLastWrite() = 0; virtual time_t getLastWrite() = 0;
virtual const char* path() const = 0; virtual const char* path() const = 0;
......
...@@ -13,11 +13,10 @@ ...@@ -13,11 +13,10 @@
// limitations under the License. // limitations under the License.
#include "vfs_api.h" #include "vfs_api.h"
#include <stdio_ext.h>
using namespace fs; using namespace fs;
#define READ_SIZE_SWITCH 128 //swithc to read func when read size > 128bytes #define DEFAULT_FILE_BUFFER_SIZE 4096
FileImplPtr VFSImpl::open(const char* fpath, const char* mode, const bool create) FileImplPtr VFSImpl::open(const char* fpath, const char* mode, const bool create)
{ {
...@@ -283,6 +282,10 @@ VFSFileImpl::VFSFileImpl(VFSImpl* fs, const char* fpath, const char* mode) ...@@ -283,6 +282,10 @@ VFSFileImpl::VFSFileImpl(VFSImpl* fs, const char* fpath, const char* mode)
if(!_f) { if(!_f) {
log_e("fopen(%s) failed", temp); log_e("fopen(%s) failed", temp);
} }
if(_f && (_stat.st_blksize == 0))
{
setvbuf(_f,NULL,_IOFBF,DEFAULT_FILE_BUFFER_SIZE);
}
} else if(S_ISDIR(_stat.st_mode)) { } else if(S_ISDIR(_stat.st_mode)) {
_isDirectory = true; _isDirectory = true;
_d = opendir(temp); _d = opendir(temp);
...@@ -310,6 +313,10 @@ VFSFileImpl::VFSFileImpl(VFSImpl* fs, const char* fpath, const char* mode) ...@@ -310,6 +313,10 @@ VFSFileImpl::VFSFileImpl(VFSImpl* fs, const char* fpath, const char* mode)
if(!_f) { if(!_f) {
log_e("fopen(%s) failed", temp); log_e("fopen(%s) failed", temp);
} }
if(_f && (_stat.st_blksize == 0))
{
setvbuf(_f,NULL,_IOFBF,DEFAULT_FILE_BUFFER_SIZE);
}
} }
} }
free(temp); free(temp);
...@@ -377,28 +384,7 @@ size_t VFSFileImpl::read(uint8_t* buf, size_t size) ...@@ -377,28 +384,7 @@ size_t VFSFileImpl::read(uint8_t* buf, size_t size)
return 0; return 0;
} }
//ERASE BYTEBUFFER and use read when size > READ_SIZE_SWITCH always return fread(buf, 1, size, _f);
if(size > READ_SIZE_SWITCH)
{
//check some data in buffer exists –> clear buffer and move pointer to deleted data
size_t bytesinbuf = __fpending(_f);
if (bytesinbuf && (bytesinbuf != 128)) //buffer lenght is 128 bytes
{
fpurge(_f);
lseek(fileno(_f),(-128+bytesinbuf),SEEK_CUR);
}
int res = ::read(fileno(_f), buf, size);
if (res < 0) {
// an error occurred
return 0;
}
return res;
}
else
{
return fread(buf, 1, size, _f);
}
} }
void VFSFileImpl::flush() void VFSFileImpl::flush()
...@@ -439,6 +425,19 @@ size_t VFSFileImpl::size() const ...@@ -439,6 +425,19 @@ size_t VFSFileImpl::size() const
return _stat.st_size; return _stat.st_size;
} }
/*
* Change size of files internal buffer used for read / write operations.
* Need to be called right after opening file before any other operation!
*/
bool VFSFileImpl::setBufferSize(size_t size)
{
if(_isDirectory || !_f) {
return 0;
}
int res = setvbuf(_f,NULL,_IOFBF,size);
return res == 0;
}
const char* VFSFileImpl::path() const const char* VFSFileImpl::path() const
{ {
return (const char*) _path; return (const char*) _path;
......
...@@ -65,10 +65,11 @@ public: ...@@ -65,10 +65,11 @@ public:
bool seek(uint32_t pos, SeekMode mode) override; bool seek(uint32_t pos, SeekMode mode) override;
size_t position() const override; size_t position() const override;
size_t size() const override; size_t size() const override;
bool setBufferSize(size_t size);
void close() override; void close() override;
const char* path() const override; const char* path() const override;
const char* name() const override; const char* name() const override;
time_t getLastWrite() override; time_t getLastWrite() override;
boolean isDirectory(void) override; boolean isDirectory(void) override;
FileImplPtr openNextFile(const char* mode) override; FileImplPtr openNextFile(const char* mode) override;
void rewindDirectory(void) override; void rewindDirectory(void) override;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment