STRATEGY(9E) Driver Entry Points STRATEGY(9E)

NAME


strategy - perform block I/O

SYNOPSIS


#include <sys/types.h>
#include <sys/buf.h>
#include <sys/ddi.h>
#include <sys/sunddi.h>


int prefixstrategy(struct buf *bp);


INTERFACE LEVEL


Architecture independent level 1 (DDI/DKI). This entry point is required
for block devices.

PARAMETERS


bp
Pointer to the buf(9S) structure.


DESCRIPTION


The strategy() routine is called indirectly (through cb_ops(9S)) by the
kernel to read and write blocks of data on the block device. strategy()
may also be called directly or indirectly to support the raw character
interface of a block device (read(9E), write(9E) and ioctl(9E)). The
strategy() routine's responsibility is to set up and initiate the
transfer.


In general, strategy() should not block. It can, however, perform a
kmem_cache_create(9F) with both the KM_PUSHPAGE and KM_SLEEP flags set,
which might block, without causing deadlock in low memory situations.

RETURN VALUES


The strategy() function must return 0. On an error condition, it should
call bioerror(9F) to set b_flags to the proper error code, and call
biodone(9F). Note that a partial transfer is not considered to be an
error.

SEE ALSO


ioctl(9E), read(9E), write(9E), biodone(9F), bioerror(9F),
kmem_cache_create(9F), buf(9S), cb_ops(9S)


Writing Device Drivers

November 6, 2003 STRATEGY(9E)