db/update/InotifySource: remove FifoBuffer
Eliminate support for partial reads. The Linux kernel will never return partial results, so this buffering was unnecessary.
This commit is contained in:
parent
c9a71a7176
commit
1f3d3970f6
@ -25,43 +25,45 @@
|
|||||||
#include "system/FatalError.hxx"
|
#include "system/FatalError.hxx"
|
||||||
#include "Log.hxx"
|
#include "Log.hxx"
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
#include <sys/inotify.h>
|
#include <sys/inotify.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <limits.h>
|
||||||
|
|
||||||
bool
|
bool
|
||||||
InotifySource::OnSocketReady(gcc_unused unsigned flags)
|
InotifySource::OnSocketReady(gcc_unused unsigned flags)
|
||||||
{
|
{
|
||||||
const auto dest = buffer.Write();
|
uint8_t buffer[4096];
|
||||||
if (dest.IsEmpty())
|
static_assert(sizeof(buffer) >= sizeof(struct inotify_event) + NAME_MAX + 1,
|
||||||
FatalError("buffer full");
|
"inotify buffer too small");
|
||||||
|
|
||||||
ssize_t nbytes = read(Get(), dest.data, dest.size);
|
ssize_t nbytes = read(Get(), buffer, sizeof(buffer));
|
||||||
if (nbytes < 0)
|
if (nbytes < 0)
|
||||||
FatalSystemError("Failed to read from inotify");
|
FatalSystemError("Failed to read from inotify");
|
||||||
if (nbytes == 0)
|
if (nbytes == 0)
|
||||||
FatalError("end of file from inotify");
|
FatalError("end of file from inotify");
|
||||||
|
|
||||||
buffer.Append(nbytes);
|
const uint8_t *p = buffer, *const end = p + nbytes;
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
const char *name;
|
const size_t remaining = end - p;
|
||||||
|
|
||||||
auto range = buffer.Read();
|
|
||||||
const struct inotify_event *event =
|
const struct inotify_event *event =
|
||||||
(const struct inotify_event *)
|
(const struct inotify_event *)p;
|
||||||
range.data;
|
if (remaining < sizeof(*event) ||
|
||||||
if (range.size < sizeof(*event) ||
|
remaining < sizeof(*event) + event->len)
|
||||||
range.size < sizeof(*event) + event->len)
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
const char *name;
|
||||||
if (event->len > 0 && event->name[event->len - 1] == 0)
|
if (event->len > 0 && event->name[event->len - 1] == 0)
|
||||||
name = event->name;
|
name = event->name;
|
||||||
else
|
else
|
||||||
name = nullptr;
|
name = nullptr;
|
||||||
|
|
||||||
callback(event->wd, event->mask, name, callback_ctx);
|
callback(event->wd, event->mask, name, callback_ctx);
|
||||||
buffer.Consume(sizeof(*event) + event->len);
|
p += sizeof(*event) + event->len;
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -21,7 +21,6 @@
|
|||||||
#define MPD_INOTIFY_SOURCE_HXX
|
#define MPD_INOTIFY_SOURCE_HXX
|
||||||
|
|
||||||
#include "event/SocketMonitor.hxx"
|
#include "event/SocketMonitor.hxx"
|
||||||
#include "util/FifoBuffer.hxx"
|
|
||||||
|
|
||||||
class Error;
|
class Error;
|
||||||
|
|
||||||
@ -32,8 +31,6 @@ class InotifySource final : private SocketMonitor {
|
|||||||
mpd_inotify_callback_t callback;
|
mpd_inotify_callback_t callback;
|
||||||
void *callback_ctx;
|
void *callback_ctx;
|
||||||
|
|
||||||
FifoBuffer<uint8_t, 4096> buffer;
|
|
||||||
|
|
||||||
InotifySource(EventLoop &_loop,
|
InotifySource(EventLoop &_loop,
|
||||||
mpd_inotify_callback_t callback, void *ctx, int fd);
|
mpd_inotify_callback_t callback, void *ctx, int fd);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user