- struct v_dnode* interim;
- const char* pathname = path;
- int errno = __vfs_walk(start, path, &interim, component, options);
- int counter = 0;
-
- // FIXME This is NOT a correct way to resolve symlink!
- while (!errno && interim->inode && (options & VFS_WALK_NOFOLLOW)) {
- if (counter >= VFS_MAX_SYMLINK) {
- errno = ELOOP;
- continue;
- }
- if ((interim->inode->itype & VFS_IFSYMLINK) &&
- interim->inode->ops->read_symlink) {
-
- lock_inode(interim->inode);
- errno =
- interim->inode->ops->read_symlink(interim->inode, &pathname);
- unlock_inode(interim->inode);
-
- if (errno) {
- break;
- }
- } else {
- break;
- }
- errno = __vfs_walk(start, pathname, &interim, component, options);
- counter++;
- }
+ // allocate a file name stack for path walking and recursion to resolve
+ // symlink
+ char* name_buffer = valloc(2048);