提交 4adeaaf5 编写于 作者: L Linus Torvalds

Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/shaggy/jfs-2.6

* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/shaggy/jfs-2.6:
  jfs: replace __inline with inline
  jfs: le*_add_cpu conversion
...@@ -2172,7 +2172,7 @@ static void dbAllocBits(struct bmap * bmp, struct dmap * dp, s64 blkno, ...@@ -2172,7 +2172,7 @@ static void dbAllocBits(struct bmap * bmp, struct dmap * dp, s64 blkno,
} }
/* update the free count for this dmap */ /* update the free count for this dmap */
dp->nfree = cpu_to_le32(le32_to_cpu(dp->nfree) - nblocks); le32_add_cpu(&dp->nfree, -nblocks);
BMAP_LOCK(bmp); BMAP_LOCK(bmp);
...@@ -2316,7 +2316,7 @@ static int dbFreeBits(struct bmap * bmp, struct dmap * dp, s64 blkno, ...@@ -2316,7 +2316,7 @@ static int dbFreeBits(struct bmap * bmp, struct dmap * dp, s64 blkno,
/* update the free count for this dmap. /* update the free count for this dmap.
*/ */
dp->nfree = cpu_to_le32(le32_to_cpu(dp->nfree) + nblocks); le32_add_cpu(&dp->nfree, nblocks);
BMAP_LOCK(bmp); BMAP_LOCK(bmp);
...@@ -3226,7 +3226,7 @@ static int dbAllocDmapBU(struct bmap * bmp, struct dmap * dp, s64 blkno, ...@@ -3226,7 +3226,7 @@ static int dbAllocDmapBU(struct bmap * bmp, struct dmap * dp, s64 blkno,
} }
/* update the free count for this dmap */ /* update the free count for this dmap */
dp->nfree = cpu_to_le32(le32_to_cpu(dp->nfree) - nblocks); le32_add_cpu(&dp->nfree, -nblocks);
/* reconstruct summary tree */ /* reconstruct summary tree */
dbInitDmapTree(dp); dbInitDmapTree(dp);
...@@ -3660,9 +3660,8 @@ static int dbInitDmap(struct dmap * dp, s64 Blkno, int nblocks) ...@@ -3660,9 +3660,8 @@ static int dbInitDmap(struct dmap * dp, s64 Blkno, int nblocks)
goto initTree; goto initTree;
} }
} else { } else {
dp->nblocks = le32_add_cpu(&dp->nblocks, nblocks);
cpu_to_le32(le32_to_cpu(dp->nblocks) + nblocks); le32_add_cpu(&dp->nfree, nblocks);
dp->nfree = cpu_to_le32(le32_to_cpu(dp->nfree) + nblocks);
} }
/* word number containing start block number */ /* word number containing start block number */
......
...@@ -61,7 +61,7 @@ ...@@ -61,7 +61,7 @@
* determine the maximum free string for four (lower level) nodes * determine the maximum free string for four (lower level) nodes
* of the tree. * of the tree.
*/ */
static __inline signed char TREEMAX(signed char *cp) static inline signed char TREEMAX(signed char *cp)
{ {
signed char tmp1, tmp2; signed char tmp1, tmp2;
......
...@@ -1019,8 +1019,7 @@ int diFree(struct inode *ip) ...@@ -1019,8 +1019,7 @@ int diFree(struct inode *ip)
/* update the free inode counts at the iag, ag and /* update the free inode counts at the iag, ag and
* map level. * map level.
*/ */
iagp->nfreeinos = le32_add_cpu(&iagp->nfreeinos, 1);
cpu_to_le32(le32_to_cpu(iagp->nfreeinos) + 1);
imap->im_agctl[agno].numfree += 1; imap->im_agctl[agno].numfree += 1;
atomic_inc(&imap->im_numfree); atomic_inc(&imap->im_numfree);
...@@ -1219,9 +1218,8 @@ int diFree(struct inode *ip) ...@@ -1219,9 +1218,8 @@ int diFree(struct inode *ip)
/* update the number of free inodes and number of free extents /* update the number of free inodes and number of free extents
* for the iag. * for the iag.
*/ */
iagp->nfreeinos = cpu_to_le32(le32_to_cpu(iagp->nfreeinos) - le32_add_cpu(&iagp->nfreeinos, -(INOSPEREXT - 1));
(INOSPEREXT - 1)); le32_add_cpu(&iagp->nfreeexts, 1);
iagp->nfreeexts = cpu_to_le32(le32_to_cpu(iagp->nfreeexts) + 1);
/* update the number of free inodes and backed inodes /* update the number of free inodes and backed inodes
* at the ag and inode map level. * at the ag and inode map level.
...@@ -2124,7 +2122,7 @@ static int diAllocBit(struct inomap * imap, struct iag * iagp, int ino) ...@@ -2124,7 +2122,7 @@ static int diAllocBit(struct inomap * imap, struct iag * iagp, int ino)
/* update the free inode count at the iag, ag, inode /* update the free inode count at the iag, ag, inode
* map levels. * map levels.
*/ */
iagp->nfreeinos = cpu_to_le32(le32_to_cpu(iagp->nfreeinos) - 1); le32_add_cpu(&iagp->nfreeinos, -1);
imap->im_agctl[agno].numfree -= 1; imap->im_agctl[agno].numfree -= 1;
atomic_dec(&imap->im_numfree); atomic_dec(&imap->im_numfree);
...@@ -2378,9 +2376,8 @@ static int diNewExt(struct inomap * imap, struct iag * iagp, int extno) ...@@ -2378,9 +2376,8 @@ static int diNewExt(struct inomap * imap, struct iag * iagp, int extno)
/* update the free inode and free extent counts for the /* update the free inode and free extent counts for the
* iag. * iag.
*/ */
iagp->nfreeinos = cpu_to_le32(le32_to_cpu(iagp->nfreeinos) + le32_add_cpu(&iagp->nfreeinos, (INOSPEREXT - 1));
(INOSPEREXT - 1)); le32_add_cpu(&iagp->nfreeexts, -1);
iagp->nfreeexts = cpu_to_le32(le32_to_cpu(iagp->nfreeexts) - 1);
/* update the free and backed inode counts for the ag. /* update the free and backed inode counts for the ag.
*/ */
......
...@@ -905,8 +905,7 @@ int xtInsert(tid_t tid, /* transaction id */ ...@@ -905,8 +905,7 @@ int xtInsert(tid_t tid, /* transaction id */
XT_PUTENTRY(xad, xflag, xoff, xlen, xaddr); XT_PUTENTRY(xad, xflag, xoff, xlen, xaddr);
/* advance next available entry index */ /* advance next available entry index */
p->header.nextindex = le16_add_cpu(&p->header.nextindex, 1);
cpu_to_le16(le16_to_cpu(p->header.nextindex) + 1);
/* Don't log it if there are no links to the file */ /* Don't log it if there are no links to the file */
if (!test_cflag(COMMIT_Nolink, ip)) { if (!test_cflag(COMMIT_Nolink, ip)) {
...@@ -997,8 +996,7 @@ xtSplitUp(tid_t tid, ...@@ -997,8 +996,7 @@ xtSplitUp(tid_t tid,
split->addr); split->addr);
/* advance next available entry index */ /* advance next available entry index */
sp->header.nextindex = le16_add_cpu(&sp->header.nextindex, 1);
cpu_to_le16(le16_to_cpu(sp->header.nextindex) + 1);
/* Don't log it if there are no links to the file */ /* Don't log it if there are no links to the file */
if (!test_cflag(COMMIT_Nolink, ip)) { if (!test_cflag(COMMIT_Nolink, ip)) {
...@@ -1167,9 +1165,7 @@ xtSplitUp(tid_t tid, ...@@ -1167,9 +1165,7 @@ xtSplitUp(tid_t tid,
JFS_SBI(ip->i_sb)->nbperpage, rcbn); JFS_SBI(ip->i_sb)->nbperpage, rcbn);
/* advance next available entry index. */ /* advance next available entry index. */
sp->header.nextindex = le16_add_cpu(&sp->header.nextindex, 1);
cpu_to_le16(le16_to_cpu(sp->header.nextindex) +
1);
/* Don't log it if there are no links to the file */ /* Don't log it if there are no links to the file */
if (!test_cflag(COMMIT_Nolink, ip)) { if (!test_cflag(COMMIT_Nolink, ip)) {
...@@ -1738,8 +1734,7 @@ int xtExtend(tid_t tid, /* transaction id */ ...@@ -1738,8 +1734,7 @@ int xtExtend(tid_t tid, /* transaction id */
XT_PUTENTRY(xad, XAD_NEW, xoff, len, xaddr); XT_PUTENTRY(xad, XAD_NEW, xoff, len, xaddr);
/* advance next available entry index */ /* advance next available entry index */
p->header.nextindex = le16_add_cpu(&p->header.nextindex, 1);
cpu_to_le16(le16_to_cpu(p->header.nextindex) + 1);
} }
/* get back old entry */ /* get back old entry */
...@@ -1905,8 +1900,7 @@ printf("xtTailgate: xoff:0x%lx xlen:0x%x xaddr:0x%lx\n", ...@@ -1905,8 +1900,7 @@ printf("xtTailgate: xoff:0x%lx xlen:0x%x xaddr:0x%lx\n",
XT_PUTENTRY(xad, XAD_NEW, xoff, xlen, xaddr); XT_PUTENTRY(xad, XAD_NEW, xoff, xlen, xaddr);
/* advance next available entry index */ /* advance next available entry index */
p->header.nextindex = le16_add_cpu(&p->header.nextindex, 1);
cpu_to_le16(le16_to_cpu(p->header.nextindex) + 1);
} }
/* get back old XAD */ /* get back old XAD */
...@@ -2567,8 +2561,7 @@ int xtAppend(tid_t tid, /* transaction id */ ...@@ -2567,8 +2561,7 @@ int xtAppend(tid_t tid, /* transaction id */
XT_PUTENTRY(xad, xflag, xoff, xlen, xaddr); XT_PUTENTRY(xad, xflag, xoff, xlen, xaddr);
/* advance next available entry index */ /* advance next available entry index */
p->header.nextindex = le16_add_cpu(&p->header.nextindex, 1);
cpu_to_le16(le16_to_cpu(p->header.nextindex) + 1);
xtlck->lwm.offset = xtlck->lwm.offset =
(xtlck->lwm.offset) ? min(index,(int) xtlck->lwm.offset) : index; (xtlck->lwm.offset) ? min(index,(int) xtlck->lwm.offset) : index;
...@@ -2631,8 +2624,7 @@ int xtDelete(tid_t tid, struct inode *ip, s64 xoff, s32 xlen, int flag) ...@@ -2631,8 +2624,7 @@ int xtDelete(tid_t tid, struct inode *ip, s64 xoff, s32 xlen, int flag)
* delete the entry from the leaf page * delete the entry from the leaf page
*/ */
nextindex = le16_to_cpu(p->header.nextindex); nextindex = le16_to_cpu(p->header.nextindex);
p->header.nextindex = le16_add_cpu(&p->header.nextindex, -1);
cpu_to_le16(le16_to_cpu(p->header.nextindex) - 1);
/* /*
* if the leaf page bocome empty, free the page * if the leaf page bocome empty, free the page
...@@ -2795,9 +2787,7 @@ xtDeleteUp(tid_t tid, struct inode *ip, ...@@ -2795,9 +2787,7 @@ xtDeleteUp(tid_t tid, struct inode *ip,
(nextindex - index - (nextindex - index -
1) << L2XTSLOTSIZE); 1) << L2XTSLOTSIZE);
p->header.nextindex = le16_add_cpu(&p->header.nextindex, -1);
cpu_to_le16(le16_to_cpu(p->header.nextindex) -
1);
jfs_info("xtDeleteUp(entry): 0x%lx[%d]", jfs_info("xtDeleteUp(entry): 0x%lx[%d]",
(ulong) parent->bn, index); (ulong) parent->bn, index);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册