lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite for Android: free password hash cracker in your pocket
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <5c49b0ed0608041117l68230f28w91e0d9a26313acfa@mail.gmail.com>
Date:	Fri, 4 Aug 2006 11:17:25 -0700
From:	"Nate Diller" <nate.diller@...il.com>
To:	"Al Boldi" <a1426z@...ab.com>
Cc:	linux-kernel@...r.kernel.org
Subject: Re: [PATCH -mm] [3/3] Add the Elevator I/O scheduler

On 8/4/06, Al Boldi <a1426z@...ab.com> wrote:
> Nate Diller wrote:
> > This is the Elevator I/O scheduler.  It is a simple one-way elevator,
>
> Thanks for yet another attempt to achieve an efficient 2.6 elevator.

hopefully it's useful for you, I'd love to see performance results one
way or the other.

>
> > +static inline char contig_char(struct el_request *e)
>
> You probably meant el_req.  Check the rest.
>
> > +static void print_queue(struct request_queue *q, struct el_data *el)
> > +{
> > +       struct el_req *e;
> > +
> > +       printel(el);
>
> Should be print_el_data.
>
> Applied against 2.6.17, it boots with this:
>         io scheduler elevator registered (default)
>         elevator: forced dispatching is broken (nr_sorted=13), please report this

damn, i thought i fixed that.

>
> > +In pure form its largest weakness is starvation of other processes due to
> > +one process writing a very large number of contiguous requests (e.g.
> > +tarring a very large tar file while other processes are trying to run).
>
> cat /dev/hda > /dev/null starves the rest of the system.

yeah, that can be worse on some systems than others, it seems to vary
a bit with file system and device driver.  some setups cause more
"breaks" in the stream of requests.

>
> > +The max_contig and max_write tunables are two (imperfect) solutions. They
> > +
> > +These two tunables are still under construction, but they have proven
> > +somewhat useful in practice.  Usually, max_contig should be the same size
> > +(in bytes) as ra_pages.
>
> It's 0 by default.  Setting it to ra_pages prints this:
>         nate 1977: max_contig went backwards

hmmm, haven't tested this recently.  dunno why that would have broken...

>
> > +
> > +  SSTF
> > +
> > +The SSTF feature was added on a whim.  It ignores the tunables, and
> > probably +breaks tracing.  I didn't ever see it perform better than SCAN,
> > but who +knows?
>
> Starves too.

oh, yeah, definitely, this algorithm is only suitable for a workload
where you want latency over fairness.  suppose i should mention that.

Thanks for your comments and testing

NATE
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ