blob: 202297d156dff6c5b166cd1cefb72b2387d744c1 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001// SPDX-License-Identifier: GPL-2.0
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * Symlink inode operations for Coda filesystem
4 * Original version: (C) 1996 P. Braam and M. Callahan
5 * Rewritten for Linux 2.1. (C) 1997 Carnegie Mellon University
6 *
7 * Carnegie Mellon encourages users to contribute improvements to
8 * the Coda project. Contact Peter Braam (coda@cs.cmu.edu).
9 */
10
11#include <linux/types.h>
12#include <linux/kernel.h>
13#include <linux/time.h>
14#include <linux/fs.h>
15#include <linux/stat.h>
16#include <linux/errno.h>
17#include <linux/pagemap.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070018
19#include <linux/coda.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070020#include <linux/coda_psdev.h>
Al Viro31a203d2011-01-12 16:36:09 -050021
22#include "coda_linux.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070023
24static int coda_symlink_filler(struct file *file, struct page *page)
25{
26 struct inode *inode = page->mapping->host;
27 int error;
28 struct coda_inode_info *cii;
29 unsigned int len = PAGE_SIZE;
Al Viro21fc61c2015-11-17 01:07:57 -050030 char *p = page_address(page);
Linus Torvalds1da177e2005-04-16 15:20:36 -070031
Linus Torvalds1da177e2005-04-16 15:20:36 -070032 cii = ITOC(inode);
Linus Torvalds1da177e2005-04-16 15:20:36 -070033
34 error = venus_readlink(inode->i_sb, &cii->c_fid, p, &len);
Linus Torvalds1da177e2005-04-16 15:20:36 -070035 if (error)
36 goto fail;
37 SetPageUptodate(page);
Linus Torvalds1da177e2005-04-16 15:20:36 -070038 unlock_page(page);
39 return 0;
40
41fail:
42 SetPageError(page);
Linus Torvalds1da177e2005-04-16 15:20:36 -070043 unlock_page(page);
44 return error;
45}
46
Christoph Hellwigf5e54d62006-06-28 04:26:44 -070047const struct address_space_operations coda_symlink_aops = {
Linus Torvalds1da177e2005-04-16 15:20:36 -070048 .readpage = coda_symlink_filler,
49};