Lines Matching full:object
20 struct cachefiles_object *object = file->private_data; in cachefiles_ondemand_fd_release() local
27 if (!object) in cachefiles_ondemand_fd_release()
30 info = object->ondemand; in cachefiles_ondemand_fd_release()
31 cache = object->volume->cache; in cachefiles_ondemand_fd_release()
38 cachefiles_ondemand_set_object_close(object); in cachefiles_ondemand_fd_release()
52 trace_cachefiles_ondemand_fd_release(object, object_id); in cachefiles_ondemand_fd_release()
53 cachefiles_put_object(object, cachefiles_obj_put_ondemand_fd); in cachefiles_ondemand_fd_release()
61 struct cachefiles_object *object = kiocb->ki_filp->private_data; in cachefiles_ondemand_fd_write_iter() local
62 struct cachefiles_cache *cache = object->volume->cache; in cachefiles_ondemand_fd_write_iter()
69 spin_lock(&object->lock); in cachefiles_ondemand_fd_write_iter()
70 file = object->file; in cachefiles_ondemand_fd_write_iter()
72 spin_unlock(&object->lock); in cachefiles_ondemand_fd_write_iter()
76 spin_unlock(&object->lock); in cachefiles_ondemand_fd_write_iter()
79 ret = __cachefiles_prepare_write(object, file, &pos, &aligned_len, len, true); in cachefiles_ondemand_fd_write_iter()
84 trace_cachefiles_ondemand_fd_write(object, file_inode(file), pos, len); in cachefiles_ondemand_fd_write_iter()
85 ret = __cachefiles_write(object, file, pos, iter, NULL, NULL); in cachefiles_ondemand_fd_write_iter()
99 struct cachefiles_object *object = filp->private_data; in cachefiles_ondemand_fd_llseek() local
103 spin_lock(&object->lock); in cachefiles_ondemand_fd_llseek()
104 file = object->file; in cachefiles_ondemand_fd_llseek()
106 spin_unlock(&object->lock); in cachefiles_ondemand_fd_llseek()
110 spin_unlock(&object->lock); in cachefiles_ondemand_fd_llseek()
121 struct cachefiles_object *object = filp->private_data; in cachefiles_ondemand_fd_ioctl() local
122 struct cachefiles_cache *cache = object->volume->cache; in cachefiles_ondemand_fd_ioctl()
135 req->object != object) { in cachefiles_ondemand_fd_ioctl()
142 trace_cachefiles_ondemand_cread(object, id); in cachefiles_ondemand_fd_ioctl()
158 * <cache_size> indicates the object size if >=0, error code if negative
197 !req->object->ondemand->ondemand_id) { in cachefiles_ondemand_copen()
204 info = req->object->ondemand; in cachefiles_ondemand_copen()
235 * cachefiles_ondemand_set_object_close(object) in cachefiles_ondemand_copen()
250 cookie = req->object->cookie; in cachefiles_ondemand_copen()
256 trace_cachefiles_ondemand_copen(req->object, id, size); in cachefiles_ondemand_copen()
258 cachefiles_ondemand_set_object_open(req->object); in cachefiles_ondemand_copen()
264 /* Need to set object close to avoid reopen status continuing */ in cachefiles_ondemand_copen()
266 cachefiles_ondemand_set_object_close(req->object); in cachefiles_ondemand_copen()
298 struct cachefiles_object *object; in cachefiles_ondemand_get_fd() local
304 object = cachefiles_grab_object(req->object, in cachefiles_ondemand_get_fd()
306 cache = object->volume->cache; in cachefiles_ondemand_get_fd()
321 &cachefiles_ondemand_fd_fops, object, O_WRONLY); in cachefiles_ondemand_get_fd()
327 spin_lock(&object->ondemand->lock); in cachefiles_ondemand_get_fd()
328 if (object->ondemand->ondemand_id > 0) { in cachefiles_ondemand_get_fd()
329 spin_unlock(&object->ondemand->lock); in cachefiles_ondemand_get_fd()
340 object->ondemand->ondemand_id = object_id; in cachefiles_ondemand_get_fd()
341 spin_unlock(&object->ondemand->lock); in cachefiles_ondemand_get_fd()
344 trace_cachefiles_ondemand_open(object, &req->msg, load); in cachefiles_ondemand_get_fd()
356 spin_lock(&object->ondemand->lock); in cachefiles_ondemand_get_fd()
357 /* Avoid marking an opened object as closed. */ in cachefiles_ondemand_get_fd()
358 if (object->ondemand->ondemand_id <= 0) in cachefiles_ondemand_get_fd()
359 cachefiles_ondemand_set_object_close(object); in cachefiles_ondemand_get_fd()
360 spin_unlock(&object->ondemand->lock); in cachefiles_ondemand_get_fd()
361 cachefiles_put_object(object, cachefiles_obj_put_ondemand_fd); in cachefiles_ondemand_get_fd()
370 cachefiles_ondemand_init_object(info->object); in ondemand_object_worker()
375 * closed object, reopen it.
376 * Skip read requests whose related object is reopening.
382 struct cachefiles_object *object; in cachefiles_ondemand_select_req() local
388 object = req->object; in cachefiles_ondemand_select_req()
389 info = object->ondemand; in cachefiles_ondemand_select_req()
390 if (cachefiles_ondemand_object_is_close(object)) { in cachefiles_ondemand_select_req()
391 cachefiles_ondemand_set_object_reopening(object); in cachefiles_ondemand_select_req()
395 if (cachefiles_ondemand_object_is_reopening(object)) in cachefiles_ondemand_select_req()
453 cachefiles_grab_object(req->object, cachefiles_obj_get_read_req); in cachefiles_ondemand_daemon_read()
463 msg->object_id = req->object->ondemand->ondemand_id; in cachefiles_ondemand_daemon_read()
477 cachefiles_put_object(req->object, cachefiles_obj_put_read_req); in cachefiles_ondemand_daemon_read()
487 static int cachefiles_ondemand_send_req(struct cachefiles_object *object, in cachefiles_ondemand_send_req() argument
493 struct cachefiles_cache *cache = object->volume->cache; in cachefiles_ondemand_send_req()
513 req->object = object; in cachefiles_ondemand_send_req()
541 cachefiles_ondemand_object_is_dropping(object)) { in cachefiles_ondemand_send_req()
551 !cachefiles_ondemand_object_is_open(object)) { in cachefiles_ondemand_send_req()
552 WARN_ON_ONCE(object->ondemand->ondemand_id == 0); in cachefiles_ondemand_send_req()
600 /* Reset the object to close state in error handling path. in cachefiles_ondemand_send_req()
602 * cachefiles_ondemand_fd_release() will set object to close. in cachefiles_ondemand_send_req()
605 !cachefiles_ondemand_object_is_dropping(object)) in cachefiles_ondemand_send_req()
606 cachefiles_ondemand_set_object_close(object); in cachefiles_ondemand_send_req()
614 struct cachefiles_object *object = req->object; in cachefiles_ondemand_init_open_req() local
615 struct fscache_cookie *cookie = object->cookie; in cachefiles_ondemand_init_open_req()
616 struct fscache_volume *volume = object->volume->vcookie; in cachefiles_ondemand_init_open_req()
632 if (!(object->cookie->advice & FSCACHE_ADV_WANT_CACHE_SIZE)) { in cachefiles_ondemand_init_open_req()
648 struct cachefiles_object *object = req->object; in cachefiles_ondemand_init_close_req() local
650 if (!cachefiles_ondemand_object_is_open(object)) in cachefiles_ondemand_init_close_req()
653 trace_cachefiles_ondemand_close(object, &req->msg); in cachefiles_ondemand_init_close_req()
665 struct cachefiles_object *object = req->object; in cachefiles_ondemand_init_read_req() local
671 trace_cachefiles_ondemand_read(object, &req->msg, load); in cachefiles_ondemand_init_read_req()
675 int cachefiles_ondemand_init_object(struct cachefiles_object *object) in cachefiles_ondemand_init_object() argument
677 struct fscache_cookie *cookie = object->cookie; in cachefiles_ondemand_init_object()
678 struct fscache_volume *volume = object->volume->vcookie; in cachefiles_ondemand_init_object()
681 if (!object->ondemand) in cachefiles_ondemand_init_object()
688 * allocated object ID if any. in cachefiles_ondemand_init_object()
690 if (cachefiles_ondemand_object_is_open(object)) in cachefiles_ondemand_init_object()
698 return cachefiles_ondemand_send_req(object, CACHEFILES_OP_OPEN, in cachefiles_ondemand_init_object()
702 void cachefiles_ondemand_clean_object(struct cachefiles_object *object) in cachefiles_ondemand_clean_object() argument
708 if (!object->ondemand) in cachefiles_ondemand_clean_object()
711 cachefiles_ondemand_send_req(object, CACHEFILES_OP_CLOSE, 0, in cachefiles_ondemand_clean_object()
714 if (!object->ondemand->ondemand_id) in cachefiles_ondemand_clean_object()
717 /* Cancel all requests for the object that is being dropped. */ in cachefiles_ondemand_clean_object()
718 cache = object->volume->cache; in cachefiles_ondemand_clean_object()
720 cachefiles_ondemand_set_object_dropping(object); in cachefiles_ondemand_clean_object()
722 if (req->object == object) { in cachefiles_ondemand_clean_object()
731 cancel_work_sync(&object->ondemand->ondemand_work); in cachefiles_ondemand_clean_object()
734 int cachefiles_ondemand_init_obj_info(struct cachefiles_object *object, in cachefiles_ondemand_init_obj_info() argument
740 object->ondemand = kzalloc(sizeof(struct cachefiles_ondemand_info), in cachefiles_ondemand_init_obj_info()
742 if (!object->ondemand) in cachefiles_ondemand_init_obj_info()
745 object->ondemand->object = object; in cachefiles_ondemand_init_obj_info()
746 spin_lock_init(&object->ondemand->lock); in cachefiles_ondemand_init_obj_info()
747 INIT_WORK(&object->ondemand->ondemand_work, ondemand_object_worker); in cachefiles_ondemand_init_obj_info()
751 void cachefiles_ondemand_deinit_obj_info(struct cachefiles_object *object) in cachefiles_ondemand_deinit_obj_info() argument
753 kfree(object->ondemand); in cachefiles_ondemand_deinit_obj_info()
754 object->ondemand = NULL; in cachefiles_ondemand_deinit_obj_info()
757 int cachefiles_ondemand_read(struct cachefiles_object *object, in cachefiles_ondemand_read() argument
762 return cachefiles_ondemand_send_req(object, CACHEFILES_OP_READ, in cachefiles_ondemand_read()