The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/cam/cam_iosched.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*-
    2  * CAM IO Scheduler Interface
    3  *
    4  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
    5  *
    6  * Copyright (c) 2015 Netflix, Inc.
    7  *
    8  * Redistribution and use in source and binary forms, with or without
    9  * modification, are permitted provided that the following conditions
   10  * are met:
   11  * 1. Redistributions of source code must retain the above copyright
   12  *    notice, this list of conditions, and the following disclaimer,
   13  *    without modification, immediately at the beginning of the file.
   14  * 2. The name of the author may not be used to endorse or promote products
   15  *    derived from this software without specific prior written permission.
   16  *
   17  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
   18  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
   19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
   20  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR
   21  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
   22  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
   23  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
   24  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
   25  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
   26  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   27  * SUCH DAMAGE.
   28  *
   29  * $FreeBSD: releng/12.0/sys/cam/cam_iosched.h 333434 2018-05-09 20:32:23Z imp $
   30  */
   31 
   32 #ifndef _CAM_CAM_IOSCHED_H
   33 #define _CAM_CAM_IOSCHED_H
   34 
   35 /* No user-serviceable parts in here. */
   36 #ifdef _KERNEL
   37 
   38 /* Forward declare all structs to keep interface thin */
   39 struct cam_iosched_softc;
   40 struct sysctl_ctx_list;
   41 struct sysctl_oid;
   42 union ccb;
   43 struct bio;
   44 
   45 /*
   46  * For 64-bit platforms, we know that uintptr_t is the same size as sbintime_t
   47  * so we can store values in it. For 32-bit systems, however, uintptr_t is only
   48  * 32-bits, so it won't fit. For those systems, store 24 bits of fraction and 8
   49  * bits of seconds. This allows us to measure an interval of up to ~256s, which
   50  * is ~200x what our current uses require. Provide some convenience functions to
   51  * get the time, subtract two times and convert back to sbintime_t in a safe way
   52  * that can be centralized.
   53  */
   54 #ifdef __LP64__
   55 #define CAM_IOSCHED_TIME_SHIFT 0
   56 #else
   57 #define CAM_IOSCHED_TIME_SHIFT 8
   58 #endif
   59 static inline uintptr_t
   60 cam_iosched_now(void)
   61 {
   62 
   63         /* Cast here is to avoid right shifting a signed value */
   64         return (uintptr_t)((uint64_t)sbinuptime() >> CAM_IOSCHED_TIME_SHIFT);
   65 }
   66 
   67 static inline uintptr_t
   68 cam_iosched_delta_t(uintptr_t then)
   69 {
   70 
   71         /* Since the types are identical, wrapping works correctly */
   72         return (cam_iosched_now() - then);
   73 }
   74 
   75 static inline sbintime_t
   76 cam_iosched_sbintime_t(uintptr_t delta)
   77 {
   78 
   79         /* Cast here is to widen the type so the left shift doesn't lose precision */
   80         return (sbintime_t)((uint64_t)delta << CAM_IOSCHED_TIME_SHIFT);
   81 }
   82 
   83 int cam_iosched_init(struct cam_iosched_softc **, struct cam_periph *periph);
   84 void cam_iosched_fini(struct cam_iosched_softc *);
   85 void cam_iosched_sysctl_init(struct cam_iosched_softc *, struct sysctl_ctx_list *, struct sysctl_oid *);
   86 struct bio *cam_iosched_next_trim(struct cam_iosched_softc *isc);
   87 struct bio *cam_iosched_get_trim(struct cam_iosched_softc *isc);
   88 struct bio *cam_iosched_next_bio(struct cam_iosched_softc *isc);
   89 void cam_iosched_queue_work(struct cam_iosched_softc *isc, struct bio *bp);
   90 void cam_iosched_flush(struct cam_iosched_softc *isc, struct devstat *stp, int err);
   91 void cam_iosched_schedule(struct cam_iosched_softc *isc, struct cam_periph *periph);
   92 void cam_iosched_finish_trim(struct cam_iosched_softc *isc);
   93 void cam_iosched_submit_trim(struct cam_iosched_softc *isc);
   94 void cam_iosched_put_back_trim(struct cam_iosched_softc *isc, struct bio *bp);
   95 void cam_iosched_set_sort_queue(struct cam_iosched_softc *isc, int val);
   96 int cam_iosched_has_work_flags(struct cam_iosched_softc *isc, uint32_t flags);
   97 void cam_iosched_set_work_flags(struct cam_iosched_softc *isc, uint32_t flags);
   98 void cam_iosched_clr_work_flags(struct cam_iosched_softc *isc, uint32_t flags);
   99 void cam_iosched_trim_done(struct cam_iosched_softc *isc);
  100 int cam_iosched_bio_complete(struct cam_iosched_softc *isc, struct bio *bp, union ccb *done_ccb);
  101 
  102 #endif
  103 #endif

Cache object: 1d85e86d863cb37af0c16b20de1e8f29


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.