X-Git-Url: http://www.aleph1.co.uk/gitweb/?p=yaffs2.git;a=blobdiff_plain;f=yaffs_packedtags2.c;h=f8030c7bea0ac89cf453d07e28924b430636945f;hp=e33e8a3ac37f1d3e118deb95624cb1243d6b5b29;hb=70c6bf2ff57c8a2fb778accdd5b4227abf273674;hpb=7f0f2c68474e11183cfbaebfd7c21ba48228f05e diff --git a/yaffs_packedtags2.c b/yaffs_packedtags2.c index e33e8a3..f8030c7 100644 --- a/yaffs_packedtags2.c +++ b/yaffs_packedtags2.c @@ -1,7 +1,7 @@ /* * YAFFS: Yet Another Flash File System. A NAND-flash specific file system. * - * Copyright (C) 2002-2007 Aleph One Ltd. + * Copyright (C) 2002-2010 Aleph One Ltd. * for Toby Churchill Ltd and Brightstar Engineering * * Created by Charles Manning @@ -97,24 +97,24 @@ void yaffs_PackTags2TagsPart(yaffs_PackedTags2TagsPart *ptt, } -void yaffs_PackTags2(yaffs_Device *dev, yaffs_PackedTags2 *pt, const yaffs_ExtendedTags *t) +void yaffs_PackTags2(yaffs_PackedTags2 *pt, const yaffs_ExtendedTags *t, int tagsECC) { yaffs_PackTags2TagsPart(&pt->t, t); - if(!dev->noTagsECC) - yaffs_ECCCalculateOther((unsigned char *)&pt->t, + if(tagsECC) + yaffs_ecc_calc_other((unsigned char *)&pt->t, sizeof(yaffs_PackedTags2TagsPart), &pt->ecc); } -void yaffs_UnpackTags2TagsPart(yaffs_ExtendedTags *t, +void yaffs_unpack_tags2tags_part(yaffs_ExtendedTags *t, yaffs_PackedTags2TagsPart *ptt) { memset(t, 0, sizeof(yaffs_ExtendedTags)); - yaffs_InitialiseTags(t); + yaffs_init_tags(t); if (ptt->sequenceNumber != 0xFFFFFFFF) { t->blockBad = 0; @@ -156,21 +156,21 @@ void yaffs_UnpackTags2TagsPart(yaffs_ExtendedTags *t, } -void yaffs_UnpackTags2(yaffs_Device *dev, yaffs_ExtendedTags *t, yaffs_PackedTags2 *pt) +void yaffs_unpack_tags2(yaffs_ExtendedTags *t, yaffs_PackedTags2 *pt, int tagsECC) { yaffs_ECCResult eccResult = YAFFS_ECC_RESULT_NO_ERROR; if (pt->t.sequenceNumber != 0xFFFFFFFF && - !dev->noTagsECC){ + tagsECC){ /* Chunk is in use and we need to do ECC */ yaffs_ECCOther ecc; int result; - yaffs_ECCCalculateOther((unsigned char *)&pt->t, + yaffs_ecc_calc_other((unsigned char *)&pt->t, sizeof(yaffs_PackedTags2TagsPart), &ecc); - result = yaffs_ECCCorrectOther((unsigned char *)&pt->t, + result = yaffs_ecc_correct_other((unsigned char *)&pt->t, sizeof(yaffs_PackedTags2TagsPart), &pt->ecc, &ecc); switch (result) { @@ -188,7 +188,7 @@ void yaffs_UnpackTags2(yaffs_Device *dev, yaffs_ExtendedTags *t, yaffs_PackedTag } } - yaffs_UnpackTags2TagsPart(t, &pt->t); + yaffs_unpack_tags2tags_part(t, &pt->t); t->eccResult = eccResult;