Lines Matching refs:er
348 struct gfs2_ea_request *er = ei->ei_er; in ea_list_i() local
374 if (er->er_data_len) { in ea_list_i()
375 if (ei->ei_size + ea_size > er->er_data_len) in ea_list_i()
378 memcpy(er->er_data + ei->ei_size, prefix, l); in ea_list_i()
379 memcpy(er->er_data + ei->ei_size + l, GFS2_EA2NAME(ea), in ea_list_i()
381 er->er_data[ei->ei_size + ea_size - 1] = 0; in ea_list_i()
401 struct gfs2_ea_request er; in gfs2_listxattr() local
405 memset(&er, 0, sizeof(struct gfs2_ea_request)); in gfs2_listxattr()
407 er.er_data = buffer; in gfs2_listxattr()
408 er.er_data_len = size; in gfs2_listxattr()
416 struct ea_list ei = { .ei_er = &er, .ei_size = 0 }; in gfs2_listxattr()
662 struct gfs2_ea_request *er) in ea_write() argument
667 ea->ea_data_len = cpu_to_be32(er->er_data_len); in ea_write()
668 ea->ea_name_len = er->er_name_len; in ea_write()
669 ea->ea_type = er->er_type; in ea_write()
672 memcpy(GFS2_EA2NAME(ea), er->er_name, er->er_name_len); in ea_write()
674 if (GFS2_EAREQ_SIZE_STUFFED(er) <= sdp->sd_jbsize) { in ea_write()
676 memcpy(GFS2_EA2DATA(ea), er->er_data, er->er_data_len); in ea_write()
679 const char *data = er->er_data; in ea_write()
680 unsigned int data_len = er->er_data_len; in ea_write()
684 ea->ea_num_ptrs = DIV_ROUND_UP(er->er_data_len, sdp->sd_jbsize); in ea_write()
722 struct gfs2_ea_request *er, void *private);
724 static int ea_alloc_skeleton(struct gfs2_inode *ip, struct gfs2_ea_request *er, in ea_alloc_skeleton() argument
749 error = skeleton_call(ip, er, private); in ea_alloc_skeleton()
765 static int ea_init_i(struct gfs2_inode *ip, struct gfs2_ea_request *er, in ea_init_i() argument
776 error = ea_write(ip, GFS2_EA_BH2FIRST(bh), er); in ea_init_i()
794 struct gfs2_ea_request er; in ea_init() local
798 er.er_type = type; in ea_init()
799 er.er_name = name; in ea_init()
800 er.er_name_len = strlen(name); in ea_init()
801 er.er_data = (void *)data; in ea_init()
802 er.er_data_len = size; in ea_init()
804 if (GFS2_EAREQ_SIZE_STUFFED(&er) > jbsize) in ea_init()
805 blks += DIV_ROUND_UP(er.er_data_len, jbsize); in ea_init()
807 return ea_alloc_skeleton(ip, &er, blks, ea_init_i, NULL); in ea_init()
864 struct gfs2_ea_request *er = es->es_er; in ea_set_simple_noalloc() local
876 ea_write(ip, ea, er); in ea_set_simple_noalloc()
889 struct gfs2_ea_request *er, void *private) in ea_set_simple_alloc() argument
900 error = ea_write(ip, ea, er); in ea_set_simple_alloc()
957 static int ea_set_block(struct gfs2_inode *ip, struct gfs2_ea_request *er, in ea_set_block() argument
1018 error = ea_write(ip, GFS2_EA_BH2FIRST(newbh), er); in ea_set_block()
1034 struct gfs2_ea_request er; in ea_set_i() local
1039 er.er_type = type; in ea_set_i()
1040 er.er_name = name; in ea_set_i()
1041 er.er_data = (void *)value; in ea_set_i()
1042 er.er_name_len = strlen(name); in ea_set_i()
1043 er.er_data_len = size; in ea_set_i()
1046 es.es_er = &er; in ea_set_i()
1057 if (GFS2_EAREQ_SIZE_STUFFED(&er) > GFS2_SB(&ip->i_inode)->sd_jbsize) in ea_set_i()
1058 blks += DIV_ROUND_UP(er.er_data_len, GFS2_SB(&ip->i_inode)->sd_jbsize); in ea_set_i()
1060 return ea_alloc_skeleton(ip, &er, blks, ea_set_block, el); in ea_set_i()