Thanks to Stephan Budach for reporting this.
/*
- $Id: ea.c,v 1.16 2009-11-18 10:52:00 franklahm Exp $
+ $Id: ea.c,v 1.17 2009-12-04 10:26:10 franklahm Exp $
Copyright (c) 2009 Frank Lahm <franklahm@gmail.com>
This program is free software; you can redistribute it and/or modify
LOG(log_debug, logtype_afpd, "get_easize: file: %s", uname);
if ((ea_open(vol, uname, EA_RDONLY, &ea)) != 0) {
- LOG(log_error, logtype_afpd, "get_easize: error calling ea_open for file: %s", uname);
- return AFPERR_MISC;
+ if (errno != ENOENT)
+ LOG(log_error, logtype_afpd, "get_easize: error calling ea_open for file: %s", uname);
+
+ memset(rbuf, 0, 4);
+ *rbuflen += 4;
+ return ret;
}
while (count < ea.ea_count) {
LOG(log_debug, logtype_afpd, "get_eacontent('%s/%s')", uname, attruname);
if ((ea_open(vol, uname, EA_RDONLY, &ea)) != 0) {
- LOG(log_error, logtype_afpd, "get_eacontent('%s'): ea_open error", uname);
- return AFPERR_MISC;
+ if (errno != ENOENT)
+ LOG(log_error, logtype_afpd, "get_eacontent('%s'): ea_open error", uname);
+ memset(rbuf, 0, 4);
+ *rbuflen += 4;
+ return ret;
}
while (count < ea.ea_count) {
/*
- $Id: ea_sys.c,v 1.3 2009-11-20 16:26:23 franklahm Exp $
+ $Id: ea_sys.c,v 1.4 2009-12-04 10:26:10 franklahm Exp $
Copyright (c) 2009 Frank Lahm <franklahm@gmail.com>
This program is free software; you can redistribute it and/or modify
#include <atalk/util.h>
#include <atalk/unix.h>
+#ifndef ENOATTR
+#define ENOATTR ENODATA
+#endif
+
/**********************************************************************************
* EA VFS funcs for storing EAs in nativa filesystem EAs
}
if (ret == -1) {
+ memset(rbuf, 0, 4);
+ *rbuflen += 4;
switch(errno) {
case ELOOP:
/* its a symlink and client requested O_NOFOLLOW */
LOG(log_debug, logtype_afpd, "sys_getextattr_size(%s): encountered symlink with kXAttrNoFollow", uname);
+ return AFP_OK;
- memset(rbuf, 0, 4);
- *rbuflen += 4;
+ case ENOATTR:
+ return AFPERR_MISC;
- return AFP_OK;
default:
LOG(log_error, logtype_afpd, "sys_getextattr_size: error: %s", strerror(errno));
return AFPERR_MISC;
ret = sys_getxattr(uname, attruname, rbuf +4, maxreply);
}
- if (ret == -1) switch(errno) {
- case ELOOP:
- /* its a symlink and client requested O_NOFOLLOW */
- LOG(log_debug, logtype_afpd, "sys_getextattr_content(%s): encountered symlink with kXAttrNoFollow", uname);
-
+ if (ret == -1) {
memset(rbuf, 0, 4);
*rbuflen += 4;
+ switch(errno) {
+ case ELOOP:
+ /* its a symlink and client requested O_NOFOLLOW */
+ LOG(log_debug, logtype_afpd, "sys_getextattr_content(%s): encountered symlink with kXAttrNoFollow", uname);
+ return AFP_OK;
- return AFP_OK;
- default:
- LOG(log_error, logtype_afpd, "sys_getextattr_content(%s): error: %s", attruname, strerror(errno));
- return AFPERR_MISC;
+ case ENOATTR:
+ return AFPERR_MISC;
+
+ default:
+ LOG(log_error, logtype_afpd, "sys_getextattr_content(%s): error: %s", attruname, strerror(errno));
+ return AFPERR_MISC;
+ }
}
/* remember where we must store length of attribute data in rbuf */
Copyright (C) 2001 Andreas Gruenbacher.
Samba 3.0.28, modified for netatalk.
- $Id: sys_ea.c,v 1.5 2009-11-23 19:04:15 franklahm Exp $
+ $Id: sys_ea.c,v 1.6 2009-12-04 10:26:10 franklahm Exp $
*/
#include <atalk/logger.h>
#include <atalk/ea.h>
+#ifndef ENOATTR
+#define ENOATTR ENODATA
+#endif
+
/******** Solaris EA helper function prototypes ********/
#ifdef HAVE_ATTROPEN
#define SOLARIS_ATTRMODE S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP
int filedes = attropen(path, attrpath, oflag, mode);
if (filedes == -1) {
LOG(log_maxdebug, logtype_default, "attropen FAILED: path: %s, name: %s, errno: %s\n",path,attrpath,strerror(errno));
+ errno = ENOATTR;
}
return filedes;
}