struct lu_attr attr;
struct lu_fid fid;
struct dt_object *o;
- int rc = 0;
+ int i, rc = 0;
ENTRY;
OBD_ALLOC(lut->lut_reply_bitmap,
LUT_REPLY_SLOTS_MAX_CHUNKS * sizeof(unsigned long *));
if (lut->lut_reply_bitmap == NULL)
- GOTO(out, rc);
+ GOTO(out, rc = -ENOMEM);
memset(&attr, 0, sizeof(attr));
attr.la_valid = LA_MODE;
if (lut->lut_reply_data != NULL)
lu_object_put(env, &lut->lut_reply_data->do_lu);
lut->lut_reply_data = NULL;
- if (lut->lut_reply_bitmap != NULL)
+ if (lut->lut_reply_bitmap != NULL) {
+ for (i = 0; i < LUT_REPLY_SLOTS_MAX_CHUNKS; i++) {
+ if (lut->lut_reply_bitmap[i] != NULL)
+ OBD_FREE_LARGE(lut->lut_reply_bitmap[i],
+ BITS_TO_LONGS(LUT_REPLY_SLOTS_PER_CHUNK) *
+ sizeof(long));
+ lut->lut_reply_bitmap[i] = NULL;
+ }
OBD_FREE(lut->lut_reply_bitmap,
LUT_REPLY_SLOTS_MAX_CHUNKS * sizeof(unsigned long *));
+ }
lut->lut_reply_bitmap = NULL;
return rc;
}
if (lut->lut_reply_bitmap != NULL) {
for (i = 0; i < LUT_REPLY_SLOTS_MAX_CHUNKS; i++) {
if (lut->lut_reply_bitmap[i] != NULL)
- OBD_FREE(lut->lut_reply_bitmap[i],
+ OBD_FREE_LARGE(lut->lut_reply_bitmap[i],
BITS_TO_LONGS(LUT_REPLY_SLOTS_PER_CHUNK) *
sizeof(long));
lut->lut_reply_bitmap[i] = NULL;
{
ENTRY;
- tgt_page_to_corrupt = alloc_page(GFP_IOFS);
+ tgt_page_to_corrupt = alloc_page(GFP_KERNEL);
tgt_key_init_generic(&tgt_thread_key, NULL);
lu_context_key_register_many(&tgt_thread_key, NULL);
void tgt_mod_exit(void)
{
if (tgt_page_to_corrupt != NULL)
- page_cache_release(tgt_page_to_corrupt);
+ put_page(tgt_page_to_corrupt);
lu_context_key_degister(&tgt_thread_key);
lu_context_key_degister(&tgt_session_key);