Lines Matching refs:miter
800 void sg_miter_start(struct sg_mapping_iter *miter, struct scatterlist *sgl, in sg_miter_start() argument
803 memset(miter, 0, sizeof(struct sg_mapping_iter)); in sg_miter_start()
805 __sg_page_iter_start(&miter->piter, sgl, nents, 0); in sg_miter_start()
807 miter->__flags = flags; in sg_miter_start()
811 static bool sg_miter_get_next_page(struct sg_mapping_iter *miter) in sg_miter_get_next_page() argument
813 if (!miter->__remaining) { in sg_miter_get_next_page()
816 if (!__sg_page_iter_next(&miter->piter)) in sg_miter_get_next_page()
819 sg = miter->piter.sg; in sg_miter_get_next_page()
821 miter->__offset = miter->piter.sg_pgoffset ? 0 : sg->offset; in sg_miter_get_next_page()
822 miter->piter.sg_pgoffset += miter->__offset >> PAGE_SHIFT; in sg_miter_get_next_page()
823 miter->__offset &= PAGE_SIZE - 1; in sg_miter_get_next_page()
824 miter->__remaining = sg->offset + sg->length - in sg_miter_get_next_page()
825 (miter->piter.sg_pgoffset << PAGE_SHIFT) - in sg_miter_get_next_page()
826 miter->__offset; in sg_miter_get_next_page()
827 miter->__remaining = min_t(unsigned long, miter->__remaining, in sg_miter_get_next_page()
828 PAGE_SIZE - miter->__offset); in sg_miter_get_next_page()
851 bool sg_miter_skip(struct sg_mapping_iter *miter, off_t offset) in sg_miter_skip() argument
853 sg_miter_stop(miter); in sg_miter_skip()
858 if (!sg_miter_get_next_page(miter)) in sg_miter_skip()
861 consumed = min_t(off_t, offset, miter->__remaining); in sg_miter_skip()
862 miter->__offset += consumed; in sg_miter_skip()
863 miter->__remaining -= consumed; in sg_miter_skip()
887 bool sg_miter_next(struct sg_mapping_iter *miter) in sg_miter_next() argument
889 sg_miter_stop(miter); in sg_miter_next()
895 if (!sg_miter_get_next_page(miter)) in sg_miter_next()
898 miter->page = sg_page_iter_page(&miter->piter); in sg_miter_next()
899 miter->consumed = miter->length = miter->__remaining; in sg_miter_next()
901 if (miter->__flags & SG_MITER_ATOMIC) in sg_miter_next()
902 miter->addr = kmap_atomic(miter->page) + miter->__offset; in sg_miter_next()
904 miter->addr = kmap(miter->page) + miter->__offset; in sg_miter_next()
923 void sg_miter_stop(struct sg_mapping_iter *miter) in sg_miter_stop() argument
925 WARN_ON(miter->consumed > miter->length); in sg_miter_stop()
928 if (miter->addr) { in sg_miter_stop()
929 miter->__offset += miter->consumed; in sg_miter_stop()
930 miter->__remaining -= miter->consumed; in sg_miter_stop()
932 if (miter->__flags & SG_MITER_TO_SG) in sg_miter_stop()
933 flush_dcache_page(miter->page); in sg_miter_stop()
935 if (miter->__flags & SG_MITER_ATOMIC) { in sg_miter_stop()
937 kunmap_atomic(miter->addr); in sg_miter_stop()
939 kunmap(miter->page); in sg_miter_stop()
941 miter->page = NULL; in sg_miter_stop()
942 miter->addr = NULL; in sg_miter_stop()
943 miter->length = 0; in sg_miter_stop()
944 miter->consumed = 0; in sg_miter_stop()
966 struct sg_mapping_iter miter; in sg_copy_buffer() local
974 sg_miter_start(&miter, sgl, nents, sg_flags); in sg_copy_buffer()
976 if (!sg_miter_skip(&miter, skip)) in sg_copy_buffer()
979 while ((offset < buflen) && sg_miter_next(&miter)) { in sg_copy_buffer()
982 len = min(miter.length, buflen - offset); in sg_copy_buffer()
985 memcpy(buf + offset, miter.addr, len); in sg_copy_buffer()
987 memcpy(miter.addr, buf + offset, len); in sg_copy_buffer()
992 sg_miter_stop(&miter); in sg_copy_buffer()
1081 struct sg_mapping_iter miter; in sg_zero_buffer() local
1084 sg_miter_start(&miter, sgl, nents, sg_flags); in sg_zero_buffer()
1086 if (!sg_miter_skip(&miter, skip)) in sg_zero_buffer()
1089 while (offset < buflen && sg_miter_next(&miter)) { in sg_zero_buffer()
1092 len = min(miter.length, buflen - offset); in sg_zero_buffer()
1093 memset(miter.addr, 0, len); in sg_zero_buffer()
1098 sg_miter_stop(&miter); in sg_zero_buffer()