提交 9768a10d 编写于 作者: J Joe Thornber 提交者: Mike Snitzer

dm cache policy smq: allocate cache blocks in order

Previously, cache blocks were being allocated in reverse order.  Fix
this by pulling the block off the head of the free list.

Shouldn't have any impact on performance or latency but it is more
correct to have the cache blocks allocated/mapped in ascending order.
This fix will slightly increase the chances of two adjacent oblocks
being in adjacent cblocks.
Signed-off-by: NJoe Thornber <ejt@redhat.com>
Signed-off-by: NMike Snitzer <snitzer@redhat.com>
上级 8ee18ede
...@@ -213,6 +213,19 @@ static void l_del(struct entry_space *es, struct ilist *l, struct entry *e) ...@@ -213,6 +213,19 @@ static void l_del(struct entry_space *es, struct ilist *l, struct entry *e)
l->nr_elts--; l->nr_elts--;
} }
static struct entry *l_pop_head(struct entry_space *es, struct ilist *l)
{
struct entry *e;
for (e = l_head(es, l); e; e = l_next(es, e))
if (!e->sentinel) {
l_del(es, l, e);
return e;
}
return NULL;
}
static struct entry *l_pop_tail(struct entry_space *es, struct ilist *l) static struct entry *l_pop_tail(struct entry_space *es, struct ilist *l)
{ {
struct entry *e; struct entry *e;
...@@ -719,7 +732,7 @@ static struct entry *alloc_entry(struct entry_alloc *ea) ...@@ -719,7 +732,7 @@ static struct entry *alloc_entry(struct entry_alloc *ea)
if (l_empty(&ea->free)) if (l_empty(&ea->free))
return NULL; return NULL;
e = l_pop_tail(ea->es, &ea->free); e = l_pop_head(ea->es, &ea->free);
init_entry(e); init_entry(e);
ea->nr_allocated++; ea->nr_allocated++;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册