Lines Matching full:ea
61 * | Overall EA | First FEA Element | Second FEA Element | .....
68 * written directly. An EA list may be in-lined in the inode if there is
75 dxd_t new_ea; /* dxd to replace ea when modifying xattr */
76 struct metapage *mp; /* metapage containing ea list */
77 struct jfs_ea_list *xattr; /* buffer containing ea list */
108 static inline int name_size(struct jfs_ea *ea) in name_size() argument
110 if (is_known_namespace(ea->name)) in name_size()
111 return ea->namelen; in name_size()
113 return ea->namelen + XATTR_OS2_PREFIX_LEN; in name_size()
116 static inline int copy_name(char *buffer, struct jfs_ea *ea) in copy_name() argument
118 int len = ea->namelen; in copy_name()
120 if (!is_known_namespace(ea->name)) { in copy_name()
125 memcpy(buffer, ea->name, ea->namelen); in copy_name()
126 buffer[ea->namelen] = 0; in copy_name()
137 * FUNCTION: Attempt to write an EA inline if area is available
140 * Already verified that the specified EA is small enough to fit inline
144 * ealist - EA list pointer
146 * ea - dxd_t structure to be filled in with necessary EA information
147 * if we successfully copy the EA inline
150 * Checks if the inode's inline area is available. If so, copies EA inline
151 * and sets <ea> fields appropriately. Otherwise, returns failure, EA will
157 int size, dxd_t * ea) in ea_write_inline() argument
162 * Make sure we have an EA -- the NULL EA list is valid, but you in ea_write_inline()
170 * used for an inline EA. in ea_write_inline()
172 if (!(ji->mode2 & INLINEEA) && !(ji->ea.flag & DXD_INLINE)) in ea_write_inline()
175 DXDsize(ea, size); in ea_write_inline()
176 DXDlength(ea, 0); in ea_write_inline()
177 DXDaddress(ea, 0); in ea_write_inline()
179 ea->flag = DXD_INLINE; in ea_write_inline()
182 ea->flag = 0; in ea_write_inline()
183 DXDsize(ea, 0); in ea_write_inline()
184 DXDlength(ea, 0); in ea_write_inline()
185 DXDaddress(ea, 0); in ea_write_inline()
188 if (ji->ea.flag & DXD_INLINE) in ea_write_inline()
198 * FUNCTION: Write an EA for an inode
200 * PRE CONDITIONS: EA has been verified
204 * ealist - EA list pointer
206 * ea - dxd_t structure to be filled in appropriately with where the
207 * EA was copied
209 * NOTES: Will write EA inline if able to, otherwise allocates blocks for an
215 dxd_t * ea) in ea_write() argument
229 * Quick check to see if this is an in-linable EA. Short EAs in ea_write()
233 if (!ea_write_inline(ip, ealist, size, ea)) in ea_write()
300 ea->flag = DXD_EXTENT; in ea_write()
301 DXDsize(ea, le32_to_cpu(ealist->size)); in ea_write()
302 DXDlength(ea, nblocks); in ea_write()
303 DXDaddress(ea, blkno); in ea_write()
306 if (ji->ea.flag & DXD_INLINE) in ea_write()
322 * FUNCTION: Read an inlined EA into user's buffer
326 * ealist - Pointer to buffer to fill in with EA
333 int ea_size = sizeDXD(&ji->ea); in ea_read_inline()
341 if ((sizeDXD(&ji->ea) > sizeof (ji->i_inline_ea))) in ea_read_inline()
354 * FUNCTION: copy EA data into user's buffer
358 * ealist - Pointer to buffer to fill in with EA
360 * NOTES: If EA is inline calls ea_read_inline() to copy EA.
377 /* quick check for in-line EA */ in ea_read()
378 if (ji->ea.flag & DXD_INLINE) in ea_read()
381 nbytes = sizeDXD(&ji->ea); in ea_read()
388 * Figure out how many blocks were allocated when this EA list was in ea_read()
391 nblocks = lengthDXD(&ji->ea) << sbi->l2nbperpage; in ea_read()
392 blkno = addressDXD(&ji->ea) << sbi->l2nbperpage; in ea_read()
444 int ea_size = sizeDXD(&ji->ea); in ea_get()
450 /* When fsck.jfs clears a bad ea, it doesn't clear the size */ in ea_get()
451 if (ji->ea.flag == 0) in ea_get()
473 } else if (ji->ea.flag & DXD_INLINE) { in ea_get()
482 if (!(ji->ea.flag & DXD_EXTENT)) { in ea_get()
483 jfs_error(sb, "invalid ea.flag\n"); in ea_get()
560 ea_buf->mp = read_metapage(inode, addressDXD(&ji->ea), in ea_get()
561 lengthDXD(&ji->ea) << sb->s_blocksize_bits, in ea_get()
629 /* ->xattr must point to original ea's metapage */ in ea_put()
638 if (ji->ea.flag & DXD_EXTENT) { in ea_put()
639 invalidate_dxd_metapages(inode, ji->ea); in ea_put()
640 old_blocks = lengthDXD(&ji->ea); in ea_put()
644 txEA(tid, inode, &ji->ea, &ea_buf->new_ea); in ea_put()
647 if (ji->ea.flag & DXD_INLINE) in ea_put()
650 ji->ea = ea_buf->new_ea; in ea_put()
652 txEA(tid, inode, &ji->ea, NULL); in ea_put()
653 if (ji->ea.flag & DXD_INLINE) in ea_put()
655 ji->ea.flag = 0; in ea_put()
656 ji->ea.size = 0; in ea_put()
672 struct jfs_ea *ea, *old_ea = NULL, *next_ea = NULL; in __jfs_setxattr() local
695 for (ea = FIRST_EA(ealist); ea < END_EALIST(ealist); in __jfs_setxattr()
696 ea = NEXT_EA(ea)) { in __jfs_setxattr()
697 if ((namelen == ea->namelen) && in __jfs_setxattr()
698 (memcmp(name, ea->name, namelen) == 0)) { in __jfs_setxattr()
704 old_ea = ea; in __jfs_setxattr()
705 old_ea_size = EA_SIZE(ea); in __jfs_setxattr()
706 next_ea = NEXT_EA(ea); in __jfs_setxattr()
708 new_size += EA_SIZE(ea); in __jfs_setxattr()
727 * We need to allocate more space for merged ea list. in __jfs_setxattr()
739 /* Remove old ea of the same name */ in __jfs_setxattr()
741 /* number of bytes following target EA */ in __jfs_setxattr()
751 /* Completely new ea list */ in __jfs_setxattr()
755 * The size of EA value is limitted by on-disk format up to in __jfs_setxattr()
767 ea = (struct jfs_ea *) ((char *) ealist + xattr_size); in __jfs_setxattr()
768 ea->flag = 0; in __jfs_setxattr()
769 ea->namelen = namelen; in __jfs_setxattr()
770 ea->valuelen = (cpu_to_le16(value_len)); in __jfs_setxattr()
771 memcpy(ea->name, name, namelen); in __jfs_setxattr()
772 ea->name[namelen] = 0; in __jfs_setxattr()
774 memcpy(&ea->name[namelen + 1], value, value_len); in __jfs_setxattr()
775 xattr_size += EA_SIZE(ea); in __jfs_setxattr()
789 * If we're left with an empty list, there's no ea in __jfs_setxattr()
811 struct jfs_ea *ea; in __jfs_getxattr() local
833 for (ea = FIRST_EA(ealist); ea < END_EALIST(ealist); ea = NEXT_EA(ea)) in __jfs_getxattr()
834 if ((namelen == ea->namelen) && in __jfs_getxattr()
835 memcmp(name, ea->name, namelen) == 0) { in __jfs_getxattr()
837 size = le16_to_cpu(ea->valuelen); in __jfs_getxattr()
844 value = ((char *) &ea->name) + ea->namelen + 1; in __jfs_getxattr()
861 static inline int can_list(struct jfs_ea *ea) in can_list() argument
863 return (strncmp(ea->name, XATTR_TRUSTED_PREFIX, in can_list()
875 struct jfs_ea *ea; in jfs_listxattr() local
892 for (ea = FIRST_EA(ealist); ea < END_EALIST(ealist); ea = NEXT_EA(ea)) { in jfs_listxattr()
893 if (can_list(ea)) in jfs_listxattr()
894 size += name_size(ea) + 1; in jfs_listxattr()
907 for (ea = FIRST_EA(ealist); ea < END_EALIST(ealist); ea = NEXT_EA(ea)) { in jfs_listxattr()
908 if (can_list(ea)) { in jfs_listxattr()
909 int namelen = copy_name(buffer, ea); in jfs_listxattr()