[PATCH] JFS: reduce number of synchronous transactions

Use an inline pxd list rather than an xad list in the xadlock.
When the number of extents being modified can fit with the xadlock,
a transaction can be committed asynchronously.  Using a list of
pxd's instead of xad's allows us to fit 4 extents, rather than 2.

Signed-off-by: Dave Kleikamp <shaggy@austin.ibm.com>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
Dave Kleikamp 2005-05-02 12:24:46 -06:00 committed by Linus Torvalds
parent ac09f698f1
commit 66f3131f54

View File

@ -1712,7 +1712,7 @@ static void xtLog(struct jfs_log * log, struct tblock * tblk, struct lrd * lrd,
struct maplock *maplock; struct maplock *maplock;
struct xdlistlock *xadlock; struct xdlistlock *xadlock;
struct pxd_lock *pxdlock; struct pxd_lock *pxdlock;
pxd_t *pxd; pxd_t *page_pxd;
int next, lwm, hwm; int next, lwm, hwm;
ip = tlck->ip; ip = tlck->ip;
@ -1722,7 +1722,7 @@ static void xtLog(struct jfs_log * log, struct tblock * tblk, struct lrd * lrd,
lrd->log.redopage.type = cpu_to_le16(LOG_XTREE); lrd->log.redopage.type = cpu_to_le16(LOG_XTREE);
lrd->log.redopage.l2linesize = cpu_to_le16(L2XTSLOTSIZE); lrd->log.redopage.l2linesize = cpu_to_le16(L2XTSLOTSIZE);
pxd = &lrd->log.redopage.pxd; page_pxd = &lrd->log.redopage.pxd;
if (tlck->type & tlckBTROOT) { if (tlck->type & tlckBTROOT) {
lrd->log.redopage.type |= cpu_to_le16(LOG_BTROOT); lrd->log.redopage.type |= cpu_to_le16(LOG_BTROOT);
@ -1752,9 +1752,9 @@ static void xtLog(struct jfs_log * log, struct tblock * tblk, struct lrd * lrd,
* applying the after-image to the meta-data page. * applying the after-image to the meta-data page.
*/ */
lrd->type = cpu_to_le16(LOG_REDOPAGE); lrd->type = cpu_to_le16(LOG_REDOPAGE);
// *pxd = mp->cm_pxd; // *page_pxd = mp->cm_pxd;
PXDaddress(pxd, mp->index); PXDaddress(page_pxd, mp->index);
PXDlength(pxd, PXDlength(page_pxd,
mp->logical_size >> tblk->sb->s_blocksize_bits); mp->logical_size >> tblk->sb->s_blocksize_bits);
lrd->backchain = cpu_to_le32(lmLog(log, tblk, lrd, tlck)); lrd->backchain = cpu_to_le32(lmLog(log, tblk, lrd, tlck));
@ -1776,25 +1776,31 @@ static void xtLog(struct jfs_log * log, struct tblock * tblk, struct lrd * lrd,
tlck->flag |= tlckUPDATEMAP; tlck->flag |= tlckUPDATEMAP;
xadlock->flag = mlckALLOCXADLIST; xadlock->flag = mlckALLOCXADLIST;
xadlock->count = next - lwm; xadlock->count = next - lwm;
if ((xadlock->count <= 2) && (tblk->xflag & COMMIT_LAZY)) { if ((xadlock->count <= 4) && (tblk->xflag & COMMIT_LAZY)) {
int i; int i;
pxd_t *pxd;
/* /*
* Lazy commit may allow xtree to be modified before * Lazy commit may allow xtree to be modified before
* txUpdateMap runs. Copy xad into linelock to * txUpdateMap runs. Copy xad into linelock to
* preserve correct data. * preserve correct data.
*
* We can fit twice as may pxd's as xads in the lock
*/ */
xadlock->xdlist = &xtlck->pxdlock; xadlock->flag = mlckALLOCPXDLIST;
memcpy(xadlock->xdlist, &p->xad[lwm], pxd = xadlock->xdlist = &xtlck->pxdlock;
sizeof(xad_t) * xadlock->count); for (i = 0; i < xadlock->count; i++) {
PXDaddress(pxd, addressXAD(&p->xad[lwm + i]));
for (i = 0; i < xadlock->count; i++) PXDlength(pxd, lengthXAD(&p->xad[lwm + i]));
p->xad[lwm + i].flag &= p->xad[lwm + i].flag &=
~(XAD_NEW | XAD_EXTENDED); ~(XAD_NEW | XAD_EXTENDED);
pxd++;
}
} else { } else {
/* /*
* xdlist will point to into inode's xtree, ensure * xdlist will point to into inode's xtree, ensure
* that transaction is not committed lazily. * that transaction is not committed lazily.
*/ */
xadlock->flag = mlckALLOCXADLIST;
xadlock->xdlist = &p->xad[lwm]; xadlock->xdlist = &p->xad[lwm];
tblk->xflag &= ~COMMIT_LAZY; tblk->xflag &= ~COMMIT_LAZY;
} }
@ -1836,8 +1842,8 @@ static void xtLog(struct jfs_log * log, struct tblock * tblk, struct lrd * lrd,
if (tblk->xflag & COMMIT_TRUNCATE) { if (tblk->xflag & COMMIT_TRUNCATE) {
/* write NOREDOPAGE for the page */ /* write NOREDOPAGE for the page */
lrd->type = cpu_to_le16(LOG_NOREDOPAGE); lrd->type = cpu_to_le16(LOG_NOREDOPAGE);
PXDaddress(pxd, mp->index); PXDaddress(page_pxd, mp->index);
PXDlength(pxd, PXDlength(page_pxd,
mp->logical_size >> tblk->sb-> mp->logical_size >> tblk->sb->
s_blocksize_bits); s_blocksize_bits);
lrd->backchain = lrd->backchain =
@ -1872,22 +1878,32 @@ static void xtLog(struct jfs_log * log, struct tblock * tblk, struct lrd * lrd,
* deleted page itself; * deleted page itself;
*/ */
tlck->flag |= tlckUPDATEMAP; tlck->flag |= tlckUPDATEMAP;
xadlock->flag = mlckFREEXADLIST;
xadlock->count = hwm - XTENTRYSTART + 1; xadlock->count = hwm - XTENTRYSTART + 1;
if ((xadlock->count <= 2) && (tblk->xflag & COMMIT_LAZY)) { if ((xadlock->count <= 4) && (tblk->xflag & COMMIT_LAZY)) {
int i;
pxd_t *pxd;
/* /*
* Lazy commit may allow xtree to be modified before * Lazy commit may allow xtree to be modified before
* txUpdateMap runs. Copy xad into linelock to * txUpdateMap runs. Copy xad into linelock to
* preserve correct data. * preserve correct data.
*
* We can fit twice as may pxd's as xads in the lock
*/ */
xadlock->xdlist = &xtlck->pxdlock; xadlock->flag = mlckFREEPXDLIST;
memcpy(xadlock->xdlist, &p->xad[XTENTRYSTART], pxd = xadlock->xdlist = &xtlck->pxdlock;
sizeof(xad_t) * xadlock->count); for (i = 0; i < xadlock->count; i++) {
PXDaddress(pxd,
addressXAD(&p->xad[XTENTRYSTART + i]));
PXDlength(pxd,
lengthXAD(&p->xad[XTENTRYSTART + i]));
pxd++;
}
} else { } else {
/* /*
* xdlist will point to into inode's xtree, ensure * xdlist will point to into inode's xtree, ensure
* that transaction is not committed lazily. * that transaction is not committed lazily.
*/ */
xadlock->flag = mlckFREEXADLIST;
xadlock->xdlist = &p->xad[XTENTRYSTART]; xadlock->xdlist = &p->xad[XTENTRYSTART];
tblk->xflag &= ~COMMIT_LAZY; tblk->xflag &= ~COMMIT_LAZY;
} }
@ -1918,7 +1934,7 @@ static void xtLog(struct jfs_log * log, struct tblock * tblk, struct lrd * lrd,
* header ? * header ?
*/ */
if (tlck->type & tlckTRUNCATE) { if (tlck->type & tlckTRUNCATE) {
pxd_t tpxd; /* truncated extent of xad */ pxd_t pxd; /* truncated extent of xad */
int twm; int twm;
/* /*
@ -1947,8 +1963,9 @@ static void xtLog(struct jfs_log * log, struct tblock * tblk, struct lrd * lrd,
* applying the after-image to the meta-data page. * applying the after-image to the meta-data page.
*/ */
lrd->type = cpu_to_le16(LOG_REDOPAGE); lrd->type = cpu_to_le16(LOG_REDOPAGE);
PXDaddress(pxd, mp->index); PXDaddress(page_pxd, mp->index);
PXDlength(pxd, mp->logical_size >> tblk->sb->s_blocksize_bits); PXDlength(page_pxd,
mp->logical_size >> tblk->sb->s_blocksize_bits);
lrd->backchain = cpu_to_le32(lmLog(log, tblk, lrd, tlck)); lrd->backchain = cpu_to_le32(lmLog(log, tblk, lrd, tlck));
/* /*
@ -1966,7 +1983,7 @@ static void xtLog(struct jfs_log * log, struct tblock * tblk, struct lrd * lrd,
lrd->log.updatemap.type = cpu_to_le16(LOG_FREEPXD); lrd->log.updatemap.type = cpu_to_le16(LOG_FREEPXD);
lrd->log.updatemap.nxd = cpu_to_le16(1); lrd->log.updatemap.nxd = cpu_to_le16(1);
lrd->log.updatemap.pxd = pxdlock->pxd; lrd->log.updatemap.pxd = pxdlock->pxd;
tpxd = pxdlock->pxd; /* save to format maplock */ pxd = pxdlock->pxd; /* save to format maplock */
lrd->backchain = lrd->backchain =
cpu_to_le32(lmLog(log, tblk, lrd, NULL)); cpu_to_le32(lmLog(log, tblk, lrd, NULL));
} }
@ -2035,7 +2052,7 @@ static void xtLog(struct jfs_log * log, struct tblock * tblk, struct lrd * lrd,
pxdlock = (struct pxd_lock *) xadlock; pxdlock = (struct pxd_lock *) xadlock;
pxdlock->flag = mlckFREEPXD; pxdlock->flag = mlckFREEPXD;
pxdlock->count = 1; pxdlock->count = 1;
pxdlock->pxd = tpxd; pxdlock->pxd = pxd;
jfs_info("xtLog: truncate ip:0x%p mp:0x%p count:%d " jfs_info("xtLog: truncate ip:0x%p mp:0x%p count:%d "
"hwm:%d", ip, mp, pxdlock->count, hwm); "hwm:%d", ip, mp, pxdlock->count, hwm);