summaryrefslogtreecommitdiffstats
path: root/sesman
diff options
context:
space:
mode:
authorLaxmikant Rashinkar <LK.Rashinkar@gmail.com>2013-08-11 18:06:39 -0700
committerLaxmikant Rashinkar <LK.Rashinkar@gmail.com>2013-08-11 18:06:39 -0700
commit6381941c78b19c14be1daba712833cfa0f7b2b0c (patch)
treef3c1e955ce4feab15e0df287ea3dcb29022ac704 /sesman
parentd2de1b703be307ffd36e618cef68b3976ddf548d (diff)
downloadxrdp-proprietary-6381941c78b19c14be1daba712833cfa0f7b2b0c.tar.gz
xrdp-proprietary-6381941c78b19c14be1daba712833cfa0f7b2b0c.zip
FUSE: changed architecture to use opendir/readdir instead of just readdir
Diffstat (limited to 'sesman')
-rw-r--r--sesman/chansrv/chansrv_fuse.c456
-rw-r--r--sesman/chansrv/devredir.c2
-rw-r--r--sesman/chansrv/smartcard_pcsc.c88
3 files changed, 260 insertions, 286 deletions
diff --git a/sesman/chansrv/chansrv_fuse.c b/sesman/chansrv/chansrv_fuse.c
index f43c91ef..572679eb 100644
--- a/sesman/chansrv/chansrv_fuse.c
+++ b/sesman/chansrv/chansrv_fuse.c
@@ -217,6 +217,12 @@ struct req_list_item
int size;
};
+struct dir_info
+{
+ /* last index accessed in g_xrdp_fs.inode_table[] */
+ int index;
+};
+
static struct list *g_req_list = 0;
static struct xrdp_fs g_xrdp_fs; /* an inst of xrdp file system */
static char *g_mount_point = 0; /* our FUSE mount point */
@@ -339,6 +345,12 @@ int clipboard_request_file_data(int stream_id, int lindex, int offset,
static void xfuse_cb_setattr(fuse_req_t req, fuse_ino_t ino, struct stat *attr,
int to_set, struct fuse_file_info *fi);
+static void xfuse_cb_opendir(fuse_req_t req, fuse_ino_t ino,
+ struct fuse_file_info *fi);
+
+static void xfuse_cb_releasedir(fuse_req_t req, fuse_ino_t ino,
+ struct fuse_file_info *fi);
+
/* misc calls */
static void xfuse_mark_as_stale(int pinode);
static void xfuse_delete_stale_entries(int pinode);
@@ -393,20 +405,22 @@ int xfuse_init()
/* setup FUSE callbacks */
g_memset(&g_xfuse_ops, 0, sizeof(g_xfuse_ops));
- g_xfuse_ops.lookup = xfuse_cb_lookup;
- g_xfuse_ops.readdir = xfuse_cb_readdir;
- g_xfuse_ops.mkdir = xfuse_cb_mkdir;
- g_xfuse_ops.rmdir = xfuse_cb_rmdir;
- g_xfuse_ops.unlink = xfuse_cb_unlink;
- g_xfuse_ops.rename = xfuse_cb_rename;
- g_xfuse_ops.open = xfuse_cb_open;
- g_xfuse_ops.release = xfuse_cb_release;
- g_xfuse_ops.read = xfuse_cb_read;
- g_xfuse_ops.write = xfuse_cb_write;
- g_xfuse_ops.create = xfuse_cb_create;
+ g_xfuse_ops.lookup = xfuse_cb_lookup;
+ g_xfuse_ops.readdir = xfuse_cb_readdir;
+ g_xfuse_ops.mkdir = xfuse_cb_mkdir;
+ g_xfuse_ops.rmdir = xfuse_cb_rmdir;
+ g_xfuse_ops.unlink = xfuse_cb_unlink;
+ g_xfuse_ops.rename = xfuse_cb_rename;
+ g_xfuse_ops.open = xfuse_cb_open;
+ g_xfuse_ops.release = xfuse_cb_release;
+ g_xfuse_ops.read = xfuse_cb_read;
+ g_xfuse_ops.write = xfuse_cb_write;
+ g_xfuse_ops.create = xfuse_cb_create;
//g_xfuse_ops.fsync = xfuse_cb_fsync; /* LK_TODO delete this */
- g_xfuse_ops.getattr = xfuse_cb_getattr;
- g_xfuse_ops.setattr = xfuse_cb_setattr;
+ g_xfuse_ops.getattr = xfuse_cb_getattr;
+ g_xfuse_ops.setattr = xfuse_cb_setattr;
+ g_xfuse_ops.opendir = xfuse_cb_opendir;
+ g_xfuse_ops.releasedir = xfuse_cb_releasedir;
fuse_opt_add_arg(&args, "xrdp-chansrv");
fuse_opt_add_arg(&args, g_fuse_root_path);
@@ -1172,9 +1186,6 @@ static struct xrdp_inode * xfuse_create_file_in_xrdp_fs(tui32 device_id,
log_debug("incremented nentries; parent=%d nentries=%d",
pinode, xinodep->nentries);
- /* LK_TODO */
- xfuse_dump_fs();
-
return xinode;
}
@@ -1331,6 +1342,8 @@ static void xfuse_update_xrdpfs_size()
g_xrdp_fs.inode_table = vp;
}
+/* LK_TODO do we still need this function */
+#if 0
static void xfuse_enum_dir(fuse_req_t req, fuse_ino_t ino, size_t size,
off_t off, struct fuse_file_info *fi)
{
@@ -1381,6 +1394,7 @@ static void xfuse_enum_dir(fuse_req_t req, fuse_ino_t ino, size_t size,
if (b.p)
free(b.p);
}
+#endif
/******************************************************************************
** **
@@ -1394,8 +1408,8 @@ static void xfuse_enum_dir(fuse_req_t req, fuse_ino_t ino, size_t size,
void xfuse_devredir_cb_enum_dir(void *vp, struct xrdp_inode *xinode)
{
- XFUSE_INFO *fip = (XFUSE_INFO *) vp;
- XRDP_INODE *xip = NULL;
+ XFUSE_INFO *fip = (XFUSE_INFO *) vp;
+ XRDP_INODE *xip = NULL;
if ((fip == NULL) || (xinode == NULL))
{
@@ -1403,14 +1417,14 @@ void xfuse_devredir_cb_enum_dir(void *vp, struct xrdp_inode *xinode)
return;
}
- log_debug("fip->req=%p", fip->req);
-
if (!xfuse_is_inode_valid(fip->inode))
{
log_error("inode %d is not valid", fip->inode);
return;
}
+ log_debug("parent_inode=%d name=%s", fip->inode, xinode->name);
+
/* if filename is . or .. don't add it */
if ((strcmp(xinode->name, ".") == 0) || (strcmp(xinode->name, "..") == 0))
{
@@ -1418,6 +1432,8 @@ void xfuse_devredir_cb_enum_dir(void *vp, struct xrdp_inode *xinode)
return;
}
+ xfuse_dump_fs();
+
if ((xip = xfuse_get_inode_from_pinode_name(fip->inode, xinode->name)) != NULL)
{
log_debug("inode=%d name=%s already exists in xrdp_fs; not adding it",
@@ -1437,8 +1453,10 @@ void xfuse_devredir_cb_enum_dir(void *vp, struct xrdp_inode *xinode)
/* insert it in xrdp fs and update lookup count */
g_xrdp_fs.inode_table[xinode->inode] = xinode;
- g_xrdp_fs.inode_table[fip->inode]->nentries++; /* this was missing */
+ g_xrdp_fs.inode_table[fip->inode]->nentries++;
xfuse_update_xrdpfs_size();
+
+ xfuse_dump_fs();
}
/**
@@ -1446,23 +1464,16 @@ void xfuse_devredir_cb_enum_dir(void *vp, struct xrdp_inode *xinode)
void xfuse_devredir_cb_enum_dir_done(void *vp, tui32 IoStatus)
{
- log_debug(">>>>>> vp=%p IoStatus=0x%x", vp, IoStatus);
+ XFUSE_INFO *fip;
+ struct dir_info *di;
- if (vp == NULL)
- return;
-
- XRDP_INODE *xinode;
- XRDP_INODE *ti;
- struct dirbuf1 b;
- int i;
- int first_time = 1;
-
- XFUSE_INFO *fip = (XFUSE_INFO *) vp;
+ log_debug("vp=%p IoStatus=0x%x", vp, IoStatus);
+ fip = (XFUSE_INFO *) vp;
if (fip == NULL)
{
log_debug("fip is NULL");
- goto done;
+ return;
}
if (IoStatus != 0)
@@ -1484,168 +1495,19 @@ void xfuse_devredir_cb_enum_dir_done(void *vp, tui32 IoStatus)
xfuse_delete_stale_entries(fip->inode);
-#if 0
- memset(&b, 0, sizeof(struct dirbuf));
-#else
- b.bytes_in_buf = 0;
-#endif
- for (i = FIRST_INODE; i < g_xrdp_fs.num_entries; i++)
- {
- if ((xinode = g_xrdp_fs.inode_table[i]) == NULL)
- continue;
-
- /* match parent inode */
- if (xinode->parent_inode != fip->inode)
- continue;
-
- xinode->is_synced = 1;
+ /* this will be used by xfuse_cb_readdir() */
+ di = calloc(1, sizeof(struct dir_info));
+ di->index = FIRST_INODE;
+ fip->fi->fh = (long) di;
- if (first_time)
- {
- first_time = 0;
- ti = g_xrdp_fs.inode_table[fip->inode];
-#if 0
- xfuse_dirbuf_add(fip->req, &b, ".", fip->inode);
- xfuse_dirbuf_add(fip->req, &b, "..", ti->parent_inode);
-#else
- xfuse_dirbuf_add1(fip->req, &b, ".", fip->inode);
- xfuse_dirbuf_add1(fip->req, &b, "..", ti->parent_inode);
-#endif
- }
-#if 0
- xfuse_dirbuf_add(fip->req, &b, xinode->name, xinode->inode);
-#else
- xfuse_dirbuf_add1(fip->req, &b, xinode->name, xinode->inode);
-#endif
- }
-
- if ((first_time == 0) && (fip->invoke_fuse))
- {
- if (fip->off < b.bytes_in_buf)
- {
-#if 0
- fuse_reply_buf(fip->req, b.p + fip->off,
- min(b.size - fip->off, fip->size));
-#else
- log_debug("calling fuse_reply_buf() with data...");
- fuse_reply_buf(fip->req, b.buf, b.bytes_in_buf);
- log_debug("calling fuse_reply_buf() with data...done");
-#endif
- }
- else
- {
- log_debug("calling fuse_reply_buf() with NULL...");
- fuse_reply_buf(fip->req, NULL, 0);
- log_debug("calling fuse_reply_buf() with NULL...done");
- }
- }
- else
- {
- log_debug("calling fuse_reply_err()...");
- fuse_reply_err(fip->req, ENOENT);
- log_debug("calling fuse_reply_err()...done");
- }
+ fuse_reply_open(fip->req, fip->fi);
done:
-#if 0
- if (b.p)
- free(b.p);
-#endif
-
- if (!fip)
- printf("###### %s : %s : %d: fip is NULL\n", __FILE__, __func__, __LINE__);
-
if (fip)
free(fip);
}
-void xfuse_devredir_cb_enum_dir_done_TODO(void *vp, tui32 IoStatus)
-{
- struct xrdp_inode *xinode;
- struct fuse_entry_param e;
- int i;
-
- XFUSE_INFO *fip = (XFUSE_INFO *) vp;
-
- printf("--------- xfuse_devredir_cb_enum_dir_done() entered\n");
-
- xfuse_dump_fs();
-
- if (fip == NULL)
- {
- log_debug("fip is NULL");
- goto done;
- }
-
- if (IoStatus != 0)
- {
- /* command failed */
- if (fip->invoke_fuse)
- fuse_reply_err(fip->req, ENOENT);
- goto done;
- }
-
- /* do we have a valid inode? */
- if (!xfuse_is_inode_valid(fip->inode))
- {
- log_error("inode %d is not valid", fip->inode);
- if (fip->invoke_fuse)
- fuse_reply_err(fip->req, EBADF);
- goto done;
- }
-
- log_debug("looking for parent_inode=%d name=%s", fip->inode, fip->name);
-
- for (i = FIRST_INODE; i < g_xrdp_fs.num_entries; i++)
- {
- if ((xinode = g_xrdp_fs.inode_table[i]) == NULL)
- continue;
-
- /* match parent inode */
- if (xinode->parent_inode != fip->inode)
- continue;
-
- /* match name */
- if (strcmp(xinode->name, fip->name) != 0)
- continue;
-
- memset(&e, 0, sizeof(e));
- e.ino = xinode->inode;
- e.attr_timeout = XFUSE_ATTR_TIMEOUT;
- e.entry_timeout = XFUSE_ENTRY_TIMEOUT;
- e.attr.st_ino = xinode->inode;
- e.attr.st_mode = xinode->mode;
- e.attr.st_nlink = xinode->nlink;
- e.attr.st_uid = xinode->uid;
- e.attr.st_gid = xinode->gid;
- e.attr.st_size = xinode->size;
- e.attr.st_atime = xinode->atime;
- e.attr.st_mtime = xinode->mtime;
- e.attr.st_ctime = xinode->ctime;
- e.generation = 1;
-
- xinode->is_synced = 1;
-
- if (fip->invoke_fuse)
- fuse_reply_entry(fip->req, &e);
-
- break;
- }
-
- if (i == g_xrdp_fs.num_entries)
- {
- /* requested entry not found */
- log_debug("did NOT find entry");
- if (fip->invoke_fuse)
- fuse_reply_err(fip->req, ENOENT);
- }
-
-done:
-
- free(fip);
-}
-
void xfuse_devredir_cb_open_file(void *vp, tui32 IoStatus, tui32 DeviceId,
tui32 FileId)
{
@@ -1711,7 +1573,7 @@ void xfuse_devredir_cb_open_file(void *vp, tui32 IoStatus, tui32 DeviceId,
{
if (fip->reply_type == RT_FUSE_REPLY_OPEN)
{
- log_debug("LK_TODO sending fuse_reply_open(); "
+ log_debug("sending fuse_reply_open(); "
"DeviceId=%d FileId=%d req=%p fi=%p",
fh->DeviceId, fh->FileId, fip->req, fip->fi);
@@ -2108,14 +1970,17 @@ static int xfuse_dirbuf_add1(fuse_req_t req, struct dirbuf1 *b,
static void xfuse_cb_readdir(fuse_req_t req, fuse_ino_t ino, size_t size,
off_t off, struct fuse_file_info *fi)
{
- XRDP_INODE *xinode;
- XFUSE_INFO *fip;
- tui32 device_id;
- char full_path[4096];
- char *cptr;
+ XRDP_INODE *xinode;
+ XRDP_INODE *ti;
+ struct dir_info *di;
+ struct dirbuf1 b;
+ int i;
+ int first_time;
- log_debug("req=%p inode=%d size=%d offset=%d", req, ino, size, off);
+ log_debug("req=%p inode=%d name=%s size=%d offset=%d", req, ino,
+ g_xrdp_fs.inode_table[ino]->name, size, off);
+ /* do we have a valid inode? */
if (!xfuse_is_inode_valid(ino))
{
log_error("inode %d is not valid", ino);
@@ -2123,83 +1988,44 @@ static void xfuse_cb_readdir(fuse_req_t req, fuse_ino_t ino, size_t size,
return;
}
- if (ino == 1)
- {
- /* special case; enumerate top level dir */
- log_debug("enumerating top level dir");
- xfuse_enum_dir(req, ino, size, off, fi);
- return;
- }
-
- xinode = g_xrdp_fs.inode_table[ino];
- if (xinode->is_loc_resource)
- {
- /* enumerate local resources */
- xfuse_enum_dir(req, ino, size, off, fi);
- return;
- }
-
- /* enumerate resources on a remote device */
-
-#ifdef USE_SYNC_FLAG
- if (xinode->is_synced)
+ di = (struct dir_info *) fi->fh;
+ if (di == NULL)
{
- xfuse_enum_dir(req, ino, size, off, fi);
+ /* something seriously wrong somewhere! */
+ fuse_reply_buf(req, 0, 0);
return;
}
- else
- {
- goto do_remote_lookup;
- }
-#endif
-do_remote_lookup:
-
- xfuse_mark_as_stale((int) ino);
-
- log_debug("did not find entry; redirecting call to dev_redir");
-
- device_id = xfuse_get_device_id_for_inode((tui32) ino, full_path);
- log_debug("dev_id=%d ino=%d full_path=%s", device_id, ino, full_path);
+ b.bytes_in_buf = 0;
+ first_time = (di->index == FIRST_INODE) ? 1 : 0;
- if ((fip = calloc(1, sizeof(XFUSE_INFO))) == NULL)
+ for (i = di->index; i < g_xrdp_fs.num_entries; i++, di->index++)
{
- log_error("system out of memory");
- fuse_reply_err(req, ENOMEM);
- return;
- }
-
- fip->req = req;
- fip->inode = ino;
- fip->size = size;
- fip->off = off;
- fip->fi = fi;
- fip->dirbuf1.first_time = 1;
- fip->dirbuf1.bytes_in_buf = 0;
+ if ((xinode = g_xrdp_fs.inode_table[i]) == NULL)
+ continue;
- fip->invoke_fuse = 1;
- fip->device_id = device_id;
+ /* match parent inode */
+ if (xinode->parent_inode != ino)
+ continue;
- log_debug("fip->req=%p", fip->req);
+ xinode->is_synced = 1;
- /* we want path minus 'root node of the share' */
- if ((cptr = strchr(full_path, '/')) == NULL)
- {
- /* enumerate root dir */
- if (dev_redir_get_dir_listing((void *) fip, device_id, "\\"))
+ if (first_time)
{
- log_error("failed to send dev_redir_get_dir_listing() cmd");
- fuse_reply_buf(req, NULL, 0);
+ first_time = 0;
+ ti = g_xrdp_fs.inode_table[ino];
+ xfuse_dirbuf_add1(req, &b, ".", ino);
+ xfuse_dirbuf_add1(req, &b, "..", ti->parent_inode);
}
+
+ if (xfuse_dirbuf_add1(req, &b, xinode->name, xinode->inode))
+ break; /* buffer is full */
}
+
+ if (b.bytes_in_buf)
+ fuse_reply_buf(req, b.buf, b.bytes_in_buf);
else
- {
- if (dev_redir_get_dir_listing((void *) fip, device_id, cptr))
- {
- log_error("failed to send dev_redir_get_dir_listing() cmd");
- fuse_reply_buf(req, NULL, 0);
- }
- }
+ fuse_reply_buf(req, NULL, 0);
}
/**
@@ -2743,7 +2569,7 @@ static void xfuse_cb_release(fuse_req_t req, fuse_ino_t ino, struct
FileId = handle->FileId;
free(handle);
- fip->fi->fh = NULL;
+ fip->fi->fh = 0;
xinode->close_in_progress = 1;
if (devredir_file_close((void *) fip, fip->device_id, handle->FileId))
@@ -2987,6 +2813,118 @@ static void xfuse_cb_setattr(fuse_req_t req, fuse_ino_t ino, struct stat *attr,
fuse_reply_attr(req, &st, 1.0); /* LK_TODO just faking for now */
}
+static void xfuse_cb_opendir(fuse_req_t req, fuse_ino_t ino,
+ struct fuse_file_info *fi)
+{
+ struct dir_info *di;
+ XRDP_INODE *xinode;
+ XFUSE_INFO *fip;
+ tui32 device_id;
+ char full_path[4096];
+ char *cptr;
+
+ log_debug("inode=%d name=%s", ino, g_xrdp_fs.inode_table[ino]->name);
+
+ if (!xfuse_is_inode_valid(ino))
+ {
+ log_error("inode %d is not valid", ino);
+ fuse_reply_err(req, EBADF);
+ return;
+ }
+
+ if (ino == 1)
+ goto done; /* special case; enumerate top level dir */
+
+ xinode = g_xrdp_fs.inode_table[ino];
+
+ if (xinode->is_loc_resource)
+ goto done;
+
+ /* enumerate resources on a remote device */
+
+#ifdef USE_SYNC_FLAG
+ if (xinode->is_synced)
+ {
+ xfuse_enum_dir(req, ino, size, off, fi);
+ return;
+ }
+ else
+ {
+ goto do_remote_lookup;
+ }
+#endif
+
+do_remote_lookup:
+
+ xfuse_mark_as_stale((int) ino);
+
+ log_debug("did not find entry; redirecting call to dev_redir");
+ device_id = xfuse_get_device_id_for_inode((tui32) ino, full_path);
+
+ log_debug("dev_id=%d ino=%d full_path=%s", device_id, ino, full_path);
+
+ if ((fip = calloc(1, sizeof(XFUSE_INFO))) == NULL)
+ {
+ log_error("system out of memory");
+ fuse_reply_err(req, ENOMEM);
+ return;
+ }
+
+ fip->req = req;
+ fip->inode = ino;
+ fip->size = 0;
+ fip->off = 0;
+ fip->fi = fi;
+ fip->dirbuf1.first_time = 1;
+ fip->dirbuf1.bytes_in_buf = 0;
+
+ fip->invoke_fuse = 1;
+ fip->device_id = device_id;
+
+ /* we want path minus 'root node of the share' */
+ if ((cptr = strchr(full_path, '/')) == NULL)
+ {
+ /* enumerate root dir */
+ if (dev_redir_get_dir_listing((void *) fip, device_id, "\\"))
+ {
+ log_error("failed to send dev_redir_get_dir_listing() cmd");
+ fuse_reply_buf(req, NULL, 0);
+ }
+ }
+ else
+ {
+ if (dev_redir_get_dir_listing((void *) fip, device_id, cptr))
+ {
+ log_error("failed to send dev_redir_get_dir_listing() cmd");
+ fuse_reply_buf(req, NULL, 0);
+ }
+ }
+
+ return;
+
+done:
+
+ di = calloc(1, sizeof(struct dir_info));
+ di->index = FIRST_INODE;
+ fi->fh = (long) di;
+ fuse_reply_open(req, fi);
+}
+
+/**
+ *****************************************************************************/
+
+static void xfuse_cb_releasedir(fuse_req_t req, fuse_ino_t ino,
+ struct fuse_file_info *fi)
+{
+ struct dir_info *di;
+
+ di = (struct dir_info *) (tintptr) fi->fh;
+ if (di)
+ free(di);
+
+ fuse_reply_err(req, 0);
+}
+
/******************************************************************************
* miscellaneous functions
*****************************************************************************/
diff --git a/sesman/chansrv/devredir.c b/sesman/chansrv/devredir.c
index 57d877df..418c29e7 100644
--- a/sesman/chansrv/devredir.c
+++ b/sesman/chansrv/devredir.c
@@ -1005,7 +1005,7 @@ dev_redir_get_dir_listing(void *fusep, tui32 device_id, char *path)
{
tui32 DesiredAccess;
tui32 CreateOptions;
- tui32 CreateDisposition;
+ tui32 CreateDisposition;
int rval;
IRP *irp;
diff --git a/sesman/chansrv/smartcard_pcsc.c b/sesman/chansrv/smartcard_pcsc.c
index 5312ec5f..a3a269d7 100644
--- a/sesman/chansrv/smartcard_pcsc.c
+++ b/sesman/chansrv/smartcard_pcsc.c
@@ -33,17 +33,45 @@
#if PCSC_STANDIN
-#define LLOG_LEVEL 11
-#define LLOGLN(_level, _args) \
- do \
- { \
- if (_level < LLOG_LEVEL) \
- { \
- g_write("chansrv:smartcard [%10.10u]: ", g_time3()); \
- g_writeln _args ; \
- } \
- } \
- while (0)
+/* module based logging */
+#define LOG_ERROR 0
+#define LOG_INFO 1
+#define LOG_DEBUG 2
+#define LOG_LEVEL LOG_ERROR
+
+#define log_error(_params...) \
+{ \
+ g_write("[%10.10u]: PCSC %s: %d : ERROR: ", \
+ g_time3(), __func__, __LINE__); \
+ g_writeln (_params); \
+}
+
+#define log_always(_params...) \
+{ \
+ g_write("[%10.10u]: PCSC %s: %d : ALWAYS: ", \
+ g_time3(), __func__, __LINE__); \
+ g_writeln (_params); \
+}
+
+#define log_info(_params...) \
+{ \
+ if (LOG_INFO <= LOG_LEVEL) \
+ { \
+ g_write("[%10.10u]: PCSC %s: %d : ", \
+ g_time3(), __func__, __LINE__); \
+ g_writeln (_params); \
+ } \
+}
+
+#define log_debug(_params...) \
+{ \
+ if (LOG_DEBUG <= LOG_LEVEL) \
+ { \
+ g_write("[%10.10u]: PCSC %s: %d : ", \
+ g_time3(), __func__, __LINE__); \
+ g_writeln (_params); \
+ } \
+}
#define PCSCLITE_MSG_KEY_LEN 16
#define PCSCLITE_MAX_MESSAGE_SIZE 2048
@@ -94,7 +122,8 @@ static char g_pcsc_directory[256] = "";
int APP_CC
scard_pcsc_get_wait_objs(tbus *objs, int *count, int *timeout)
{
- LLOGLN(0, ("scard_pcsc_get_wait_objs"));
+ log_debug("scard_pcsc_get_wait_objs");
+
if (g_lis != 0)
{
trans_get_wait_objs(g_lis, objs, count);
@@ -110,7 +139,8 @@ scard_pcsc_get_wait_objs(tbus *objs, int *count, int *timeout)
int APP_CC
scard_pcsc_check_wait_objs(void)
{
- LLOGLN(0, ("scard_pcsc_check_wait_objs"));
+ log_debug("scard_pcsc_check_wait_objs");
+
if (g_lis != 0)
{
trans_check_wait_objs(g_lis);
@@ -144,8 +174,10 @@ scard_process_msg(struct stream *s)
in_uint32_le(s, msg.group_id);
in_uint32_le(s, msg.command);
in_uint64_le(s, msg.date);
- LLOGLN(0, ("scard_process_msg: mtype 0x%2.2x command 0x%2.2x",
- msg.mtype, msg.command));
+
+ log_debug("scard_process_msg: mtype 0x%2.2x command 0x%2.2x",
+ msg.mtype, msg.command);
+
rv = 0;
switch (msg.mtype)
{
@@ -166,7 +198,8 @@ my_pcsc_trans_data_in(struct trans *trans)
int size;
int error;
- LLOGLN(0, ("my_pcsc_trans_data_in:"));
+ log_debug("my_pcsc_trans_data_in:");
+
if (trans == 0)
{
return 0;
@@ -187,7 +220,7 @@ my_pcsc_trans_data_in(struct trans *trans)
int DEFAULT_CC
my_pcsc_trans_conn_in(struct trans *trans, struct trans *new_trans)
{
- LLOGLN(0, ("my_pcsc_trans_conn_in:"));
+ log_debug("my_pcsc_trans_conn_in:");
if (trans == 0)
{
@@ -207,8 +240,9 @@ my_pcsc_trans_conn_in(struct trans *trans, struct trans *new_trans)
g_con = new_trans;
g_con->trans_data_in = my_pcsc_trans_data_in;
g_con->header_size = RXSHAREDSEGMENT_BYTES;
- LLOGLN(0, ("my_pcsc_trans_conn_in: sizeof sharedSegmentMsg is %d",
- sizeof(sharedSegmentMsg)));
+
+ log_debug("my_pcsc_trans_conn_in: sizeof sharedSegmentMsg is %d",
+ sizeof(sharedSegmentMsg));
return 0;
}
@@ -220,7 +254,8 @@ scard_pcsc_init(void)
char port[256];
int error;
- LLOGLN(0, ("scard_pcsc_init:"));
+ log_debug("scard_pcsc_init:");
+
if (g_lis == 0)
{
g_lis = trans_create(2, 8192, 8192);
@@ -229,12 +264,12 @@ scard_pcsc_init(void)
{
if (g_remove_dir(g_pcsc_directory) != 0)
{
- LLOGLN(0, ("scard_pcsc_init: g_remove_dir failed"));
+ log_error("scard_pcsc_init: g_remove_dir failed");
}
}
if (g_create_dir(g_pcsc_directory) != 0)
{
- LLOGLN(0, ("scard_pcsc_init: g_create_dir failed"));
+ log_error("scard_pcsc_init: g_create_dir failed");
}
g_chmod_hex(g_pcsc_directory, 0x1777);
g_snprintf(port, 255, "%s/pcscd.comm", g_pcsc_directory);
@@ -242,8 +277,8 @@ scard_pcsc_init(void)
error = trans_listen(g_lis, port);
if (error != 0)
{
- LLOGLN(0, ("scard_pcsc_init: trans_listen failed for port %s",
- port));
+ log_error("scard_pcsc_init: trans_listen failed for port %s",
+ port);
return 1;
}
}
@@ -254,14 +289,15 @@ scard_pcsc_init(void)
int APP_CC
scard_pcsc_deinit(void)
{
- LLOGLN(0, ("scard_pcsc_deinit:"));
+ log_debug("scard_pcsc_deinit:");
+
if (g_lis != 0)
{
trans_delete(g_lis);
g_lis = 0;
if (g_remove_dir(g_pcsc_directory) != 0)
{
- LLOGLN(0, ("scard_pcsc_deinit: g_remove_dir failed"));
+ log_error("scard_pcsc_deinit: g_remove_dir failed");
}
g_pcsc_directory[0] = 0;
}