我正在尝试理解Linux阻止层,所以我正在写一篇关于它的博客:http://www.linuxintro.org/wiki/blktrAce.当这样调用blktrace时:
blktrace -d /dev/sdg -o - | blkparse -i -
我看到,例如输出
8,96 4 695 430.080106382 2356 I N 0 (00 ..) [kworker/4:2]
8,96 3 29 430.082179440 53 D N 0 (00 ..) [ksoftirqd/3]
我不明白这意味着什么.根据blkparse的手册页,有一个RWBS字段(包含R表示读取,W表示写入,B表示屏障,D表示丢弃或S表示同步).经过一些实验,我发现它是第7列.但是它包含N.这是什么意思?我在哪里可以找到这些信息的含义?
解决方法:
似乎RWBS字段中还有其他未记录的标志,并且不推荐使用屏障的“B”. N表示不丢弃,读取或写入的任何内容.
D - discard
W - write
R - read
N - None of the above
F - FUA
A - readahead
S - sync
M - metadata
static inline void fill_rwbs(char *rwbs, struct blk_io_trace *t)
{
int w = t->action & BLK_TC_ACT(BLK_TC_WRITE);
int a = t->action & BLK_TC_ACT(BLK_TC_AHEAD);
int s = t->action & BLK_TC_ACT(BLK_TC_SYNC);
int m = t->action & BLK_TC_ACT(BLK_TC_META);
int d = t->action & BLK_TC_ACT(BLK_TC_DISCARD);
int f = t->action & BLK_TC_ACT(BLK_TC_FLUSH);
int u = t->action & BLK_TC_ACT(BLK_TC_FUA);
int i = 0;
if (f)
rwbs[i++] = 'F'; /* flush */
if (d)
rwbs[i++] = 'D';
else if (w)
rwbs[i++] = 'W';
else if (t->bytes)
rwbs[i++] = 'R';
else
rwbs[i++] = 'N';
if (u)
rwbs[i++] = 'F'; /* fua */
if (a)
rwbs[i++] = 'A';
if (s)
rwbs[i++] = 'S';
if (m)
rwbs[i++] = 'M';
rwbs[i] = '\0';
}