The kernel now has support for setting port&token of a query.
The fs_shell is now able to start up to 10 concurrent live queries. Use "stopquery" to stop them all or just one of them, "startquery" to initiate one, and "lsquery" to display them all. git-svn-id: file:///srv/svn/repos/haiku/trunk/current@3334 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
b0ff9520c0
commit
6e14268838
@ -1061,26 +1061,66 @@ do_sync(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void *gQueryCookie = NULL;
|
#define MAX_LIVE_QUERIES 10
|
||||||
|
void *gQueryCookie[MAX_LIVE_QUERIES] = {NULL};
|
||||||
|
char *gQueryString[MAX_LIVE_QUERIES] = {NULL};
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
do_listqueries(int argc, char **argv)
|
||||||
|
{
|
||||||
|
int min, max;
|
||||||
|
|
||||||
|
if (argc == 2)
|
||||||
|
min = max = atol(argv[1]);
|
||||||
|
else {
|
||||||
|
min = 0;
|
||||||
|
max = MAX_LIVE_QUERIES - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// list all queries (or only the one asked for)
|
||||||
|
|
||||||
|
for (; min <= max; min++) {
|
||||||
|
if (gQueryCookie[min] == NULL)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
printf("%ld. (%p) %s\n", min, gQueryCookie[min], gQueryString[min]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
do_stopquery(int argc, char **argv)
|
do_stopquery(int argc, char **argv)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
int min, max;
|
||||||
|
|
||||||
if (gQueryCookie == NULL) {
|
if (gQueryCookie == NULL) {
|
||||||
printf("no query running (use the 'startquery' command to start a query).\n");
|
printf("no query running (use the 'startquery' command to start a query).\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = sys_close_query(true, -1, "/myfs/.", gQueryCookie);
|
if (argc == 2)
|
||||||
|
min = max = atol(argv[1]);
|
||||||
|
else {
|
||||||
|
min = 0;
|
||||||
|
max = MAX_LIVE_QUERIES - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// close all queries (or only the one asked for)
|
||||||
|
|
||||||
|
for (; min <= max; min++) {
|
||||||
|
if (gQueryCookie[min] == NULL)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
err = sys_close_query(true, -1, "/myfs/.", gQueryCookie[min]);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
printf("could not close query: %s\n", strerror(err));
|
printf("could not close query: %s\n", strerror(err));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
gQueryCookie[min] = NULL;
|
||||||
gQueryCookie = NULL;
|
free(gQueryString[min]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1088,10 +1128,17 @@ static void
|
|||||||
do_startquery(int argc, char **argv)
|
do_startquery(int argc, char **argv)
|
||||||
{
|
{
|
||||||
char *query;
|
char *query;
|
||||||
|
int freeSlot;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
if (gQueryCookie != NULL)
|
for (freeSlot = 0; freeSlot < MAX_LIVE_QUERIES; freeSlot++) {
|
||||||
do_stopquery(0, NULL);
|
if (gQueryCookie[freeSlot] == NULL)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (freeSlot == MAX_LIVE_QUERIES) {
|
||||||
|
printf("All query slots are used, stop some\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (argc != 2) {
|
if (argc != 2) {
|
||||||
printf("query string expected\n");
|
printf("query string expected\n");
|
||||||
@ -1099,12 +1146,14 @@ do_startquery(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
query = argv[1];
|
query = argv[1];
|
||||||
|
|
||||||
err = sys_open_query(true, -1, "/myfs/.", query, B_LIVE_QUERY, &gQueryCookie);
|
err = sys_open_query(true, -1, "/myfs/.", query, B_LIVE_QUERY, freeSlot, freeSlot, &gQueryCookie[freeSlot]);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
printf("could not open query: %s\n", strerror(err));
|
printf("could not open query: %s\n", strerror(err));
|
||||||
return;
|
return;
|
||||||
} else
|
}
|
||||||
printf("query started - use the 'stopquery' command to stop it.\n");
|
|
||||||
|
printf("query number %ld started - use the 'stopquery' command to stop it.\n", freeSlot);
|
||||||
|
gQueryString[freeSlot] = strdup(query);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1124,7 +1173,7 @@ do_query(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
query = argv[1];
|
query = argv[1];
|
||||||
|
|
||||||
err = sys_open_query(true, -1, "/myfs/.", query, 0, &cookie);
|
err = sys_open_query(true, -1, "/myfs/.", query, 0, 42, 42, &cookie);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
printf("could not open query: %s\n", strerror(err));
|
printf("could not open query: %s\n", strerror(err));
|
||||||
return;
|
return;
|
||||||
@ -1357,6 +1406,7 @@ cmd_entry fsh_cmds[] =
|
|||||||
{ "query", do_query, "run a query on the file system" },
|
{ "query", do_query, "run a query on the file system" },
|
||||||
{ "startquery", do_startquery, "run a live query on the file system" },
|
{ "startquery", do_startquery, "run a live query on the file system" },
|
||||||
{ "stopquery", do_stopquery, "stops the live query" },
|
{ "stopquery", do_stopquery, "stops the live query" },
|
||||||
|
{ "lsquery", do_listqueries, "list all live queries" },
|
||||||
{ "ioctl", do_ioctl, "execute ioctl() without an inode (okay, with the root node)" },
|
{ "ioctl", do_ioctl, "execute ioctl() without an inode (okay, with the root node)" },
|
||||||
{ "fcntl", do_fcntl, "execute ioctl() with the active inode" },
|
{ "fcntl", do_fcntl, "execute ioctl() with the active inode" },
|
||||||
{ "cptest", do_copytest, "copies all files from the given path" },
|
{ "cptest", do_copytest, "copies all files from the given path" },
|
||||||
|
@ -1827,7 +1827,7 @@ error1:
|
|||||||
|
|
||||||
|
|
||||||
int
|
int
|
||||||
sys_open_query(bool kernel, int fd, const char *path, const char *query, ulong flags, void **cookie)
|
sys_open_query(bool kernel, int fd, const char *path, const char *query, ulong flags, port_id port, ulong token, void **cookie)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
nspace *ns;
|
nspace *ns;
|
||||||
@ -1848,7 +1848,7 @@ sys_open_query(bool kernel, int fd, const char *path, const char *query, ulong f
|
|||||||
dec_vnode(root, FALSE);
|
dec_vnode(root, FALSE);
|
||||||
return EPERM;
|
return EPERM;
|
||||||
}
|
}
|
||||||
err = (*fs->ops.open_query)(ns->data, query, flags, -1, 0, cookie);
|
err = (*fs->ops.open_query)(ns->data, query, flags, port, token, cookie);
|
||||||
printf("sys_open_query() -- end: %d\n",err);
|
printf("sys_open_query() -- end: %d\n",err);
|
||||||
dec_vnode(root, FALSE);
|
dec_vnode(root, FALSE);
|
||||||
|
|
||||||
@ -3203,7 +3203,7 @@ notify_listener(int op, nspace_id nsid, vnode_id vnida, vnode_id vnidb, vnode_id
|
|||||||
text = "unknown operation...";
|
text = "unknown operation...";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
printf("notify_listener: %s\n",text);
|
printf("notify_listener: %s\n", text);
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -3211,11 +3211,12 @@ notify_listener(int op, nspace_id nsid, vnode_id vnida, vnode_id vnidb, vnode_id
|
|||||||
|
|
||||||
int
|
int
|
||||||
send_notification(port_id port, long token, ulong what, long op, nspace_id nsida,
|
send_notification(port_id port, long token, ulong what, long op, nspace_id nsida,
|
||||||
nspace_id nsidb, vnode_id vnida,vnode_id vnidb, vnode_id vnidc,
|
nspace_id nsidb, vnode_id vnida, vnode_id vnidb, vnode_id vnidc,
|
||||||
const char *name)
|
const char *name)
|
||||||
{
|
{
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
printf("send_notification... op = %s, name = %s\n",op == B_ENTRY_CREATED ? "B_ENTRY_CREATED" : "B_ENTRY_REMOVED",name);
|
printf("send_notification... op = %s, name = %s, port = %ld, token = %ld\n",
|
||||||
|
op == B_ENTRY_CREATED ? "B_ENTRY_CREATED" : "B_ENTRY_REMOVED", name, port, token);
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -43,7 +43,7 @@ ssize_t sys_read_attr(bool kernel, int fd, const char *name, int type, void *buf
|
|||||||
ssize_t sys_write_attr(bool kernel, int fd, const char *name, int type, void *buffer, size_t len, off_t pos);
|
ssize_t sys_write_attr(bool kernel, int fd, const char *name, int type, void *buffer, size_t len, off_t pos);
|
||||||
ssize_t sys_remove_attr(bool kernel, int fd, const char *name);
|
ssize_t sys_remove_attr(bool kernel, int fd, const char *name);
|
||||||
|
|
||||||
int sys_open_query(bool kernel, int fd, const char *path, const char *query, ulong flags, void **cookie);
|
int sys_open_query(bool kernel, int fd, const char *path, const char *query, ulong flags, port_id port, ulong token, void **cookie);
|
||||||
int sys_close_query(bool kernel, int fd, const char *path, void *cookie);
|
int sys_close_query(bool kernel, int fd, const char *path, void *cookie);
|
||||||
int sys_read_query(bool kernel, int fd, const char *path, void *cookie,struct dirent *dent,size_t bufferSize,long num);
|
int sys_read_query(bool kernel, int fd, const char *path, void *cookie,struct dirent *dent,size_t bufferSize,long num);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user