source: rtems/c/src/lib/libc/link.c @ 74835d7

Last change on this file since 74835d7 was 74835d7, checked in by Joel Sherrill <joel.sherrill@…>, on 08/11/00 at 20:04:03

2000-08-11 Chris Johns <ccj@…>

  • libc/chmod.c: Return ENOTSUP if filesystem does not have handler.
  • libc/eval.c: Ditto.
  • libc/fcntl.c: Ditto.
  • libc/fsync.c: Ditto.
  • libc/ioctl.c: Ditto.
  • libc/ioman.c: Ditto.
  • libc/link.c: Ditto.
  • libc/memfile.c: Ditto.
  • libc/mknod.c: Ditto.
  • libc/symlink.c: Ditto.
  • libc/libio.h(rtems_filesystem_dev_major_t): New macro.
  • libc/libio.h(rtems_filesystem_dev_minor_t): New macro.
  • Property mode set to 100644
File size: 2.3 KB
Line 
1/*
2 *  link() - POSIX 1003.1b - 5.3.4 - Create a new link
3 *
4 *  COPYRIGHT (c) 1989-1999.
5 *  On-Line Applications Research Corporation (OAR).
6 *
7 *  The license and distribution terms for this file may be
8 *  found in the file LICENSE in this distribution or at
9 *  http://www.OARcorp.com/rtems/license.html.
10 *
11 *  $Id$
12 */
13
14#include <rtems.h>
15#include <rtems/libio.h>
16#include <errno.h>
17
18#include "libio_.h"
19
20int link(
21  const char *existing,
22  const char *new
23)
24{
25  rtems_filesystem_location_info_t    existing_loc;
26  rtems_filesystem_location_info_t    parent_loc;
27  int                                 i;
28  int                                 result;
29  const char                         *name_start;
30
31  /*
32   * Get the node we are linking to.
33   */
34
35  result = rtems_filesystem_evaluate_path( existing, 0, &existing_loc, TRUE );
36  if ( result != 0 )
37     return -1;
38
39  /*
40   * Get the parent of the node we are creating.
41   */
42
43  rtems_filesystem_get_start_loc( new, &i, &parent_loc );
44
45  if ( !parent_loc.ops->evalformake ) {
46    rtems_filesystem_freenode( &existing_loc );
47    rtems_filesystem_freenode( &parent_loc );
48    set_errno_and_return_minus_one( ENOTSUP );
49  }
50
51  result = (*parent_loc.ops->evalformake)( &new[i], &parent_loc, &name_start );
52  if ( result != 0 ) {
53    rtems_filesystem_freenode( &existing_loc );
54    rtems_filesystem_freenode( &parent_loc );
55    set_errno_and_return_minus_one( result );
56  }
57
58  /*
59   *  Check to see if the caller is trying to link across file system
60   *  boundaries.
61   */
62
63  if ( parent_loc.mt_entry != existing_loc.mt_entry ) {
64    rtems_filesystem_freenode( &existing_loc );
65    rtems_filesystem_freenode( &parent_loc );
66    set_errno_and_return_minus_one( EXDEV );
67  }
68
69  if ( !parent_loc.ops->link ) {
70    rtems_filesystem_freenode( &existing_loc );
71    rtems_filesystem_freenode( &parent_loc );
72    set_errno_and_return_minus_one( ENOTSUP );
73  }
74
75  result = (*parent_loc.ops->link)( &existing_loc, &parent_loc, name_start );
76 
77  rtems_filesystem_freenode( &existing_loc );
78  rtems_filesystem_freenode( &parent_loc );
79
80  return result;
81}
82
83/*
84 *  _link_r
85 *
86 *  This is the Newlib dependent reentrant version of link().
87 */
88
89#if defined(RTEMS_NEWLIB)
90
91#include <reent.h>
92
93int _link_r(
94  struct _reent *ptr,
95  const char    *existing,
96  const char    *new
97)
98{
99  return link( existing, new );
100}
101#endif
102
Note: See TracBrowser for help on using the repository browser.