hw: Fix return value check for bdrv_read, bdrv_write
Those functions return -errno in case of an error. The old code would typically only detect EPERM (1) errors. Signed-off-by: Stefan Weil <sw@weilnetz.de> Signed-off-by: Stefan Hajnoczi <stefanha@gmail.com>
This commit is contained in:
		
							parent
							
								
									a14c74928b
								
							
						
					
					
						commit
						7a608f562e
					
				
							
								
								
									
										34
									
								
								hw/nand.c
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								hw/nand.c
									
									
									
									
									
								
							@ -654,7 +654,7 @@ static void glue(nand_blk_write_, PAGE_SIZE)(NANDFlashState *s)
 | 
				
			|||||||
        sector = SECTOR(s->addr);
 | 
					        sector = SECTOR(s->addr);
 | 
				
			||||||
        off = (s->addr & PAGE_MASK) + s->offset;
 | 
					        off = (s->addr & PAGE_MASK) + s->offset;
 | 
				
			||||||
        soff = SECTOR_OFFSET(s->addr);
 | 
					        soff = SECTOR_OFFSET(s->addr);
 | 
				
			||||||
        if (bdrv_read(s->bdrv, sector, iobuf, PAGE_SECTORS) == -1) {
 | 
					        if (bdrv_read(s->bdrv, sector, iobuf, PAGE_SECTORS) < 0) {
 | 
				
			||||||
            printf("%s: read error in sector %" PRIu64 "\n", __func__, sector);
 | 
					            printf("%s: read error in sector %" PRIu64 "\n", __func__, sector);
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
@ -666,22 +666,24 @@ static void glue(nand_blk_write_, PAGE_SIZE)(NANDFlashState *s)
 | 
				
			|||||||
                            MIN(OOB_SIZE, off + s->iolen - PAGE_SIZE));
 | 
					                            MIN(OOB_SIZE, off + s->iolen - PAGE_SIZE));
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if (bdrv_write(s->bdrv, sector, iobuf, PAGE_SECTORS) == -1)
 | 
					        if (bdrv_write(s->bdrv, sector, iobuf, PAGE_SECTORS) < 0) {
 | 
				
			||||||
            printf("%s: write error in sector %" PRIu64 "\n", __func__, sector);
 | 
					            printf("%s: write error in sector %" PRIu64 "\n", __func__, sector);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    } else {
 | 
					    } else {
 | 
				
			||||||
        off = PAGE_START(s->addr) + (s->addr & PAGE_MASK) + s->offset;
 | 
					        off = PAGE_START(s->addr) + (s->addr & PAGE_MASK) + s->offset;
 | 
				
			||||||
        sector = off >> 9;
 | 
					        sector = off >> 9;
 | 
				
			||||||
        soff = off & 0x1ff;
 | 
					        soff = off & 0x1ff;
 | 
				
			||||||
        if (bdrv_read(s->bdrv, sector, iobuf, PAGE_SECTORS + 2) == -1) {
 | 
					        if (bdrv_read(s->bdrv, sector, iobuf, PAGE_SECTORS + 2) < 0) {
 | 
				
			||||||
            printf("%s: read error in sector %" PRIu64 "\n", __func__, sector);
 | 
					            printf("%s: read error in sector %" PRIu64 "\n", __func__, sector);
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        mem_and(iobuf + soff, s->io, s->iolen);
 | 
					        mem_and(iobuf + soff, s->io, s->iolen);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if (bdrv_write(s->bdrv, sector, iobuf, PAGE_SECTORS + 2) == -1)
 | 
					        if (bdrv_write(s->bdrv, sector, iobuf, PAGE_SECTORS + 2) < 0) {
 | 
				
			||||||
            printf("%s: write error in sector %" PRIu64 "\n", __func__, sector);
 | 
					            printf("%s: write error in sector %" PRIu64 "\n", __func__, sector);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
    s->offset = 0;
 | 
					    s->offset = 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -704,32 +706,38 @@ static void glue(nand_blk_erase_, PAGE_SIZE)(NANDFlashState *s)
 | 
				
			|||||||
        i = SECTOR(addr);
 | 
					        i = SECTOR(addr);
 | 
				
			||||||
        page = SECTOR(addr + (ADDR_SHIFT + s->erase_shift));
 | 
					        page = SECTOR(addr + (ADDR_SHIFT + s->erase_shift));
 | 
				
			||||||
        for (; i < page; i ++)
 | 
					        for (; i < page; i ++)
 | 
				
			||||||
            if (bdrv_write(s->bdrv, i, iobuf, 1) == -1)
 | 
					            if (bdrv_write(s->bdrv, i, iobuf, 1) < 0) {
 | 
				
			||||||
                printf("%s: write error in sector %" PRIu64 "\n", __func__, i);
 | 
					                printf("%s: write error in sector %" PRIu64 "\n", __func__, i);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
    } else {
 | 
					    } else {
 | 
				
			||||||
        addr = PAGE_START(addr);
 | 
					        addr = PAGE_START(addr);
 | 
				
			||||||
        page = addr >> 9;
 | 
					        page = addr >> 9;
 | 
				
			||||||
        if (bdrv_read(s->bdrv, page, iobuf, 1) == -1)
 | 
					        if (bdrv_read(s->bdrv, page, iobuf, 1) < 0) {
 | 
				
			||||||
            printf("%s: read error in sector %" PRIu64 "\n", __func__, page);
 | 
					            printf("%s: read error in sector %" PRIu64 "\n", __func__, page);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
        memset(iobuf + (addr & 0x1ff), 0xff, (~addr & 0x1ff) + 1);
 | 
					        memset(iobuf + (addr & 0x1ff), 0xff, (~addr & 0x1ff) + 1);
 | 
				
			||||||
        if (bdrv_write(s->bdrv, page, iobuf, 1) == -1)
 | 
					        if (bdrv_write(s->bdrv, page, iobuf, 1) < 0) {
 | 
				
			||||||
            printf("%s: write error in sector %" PRIu64 "\n", __func__, page);
 | 
					            printf("%s: write error in sector %" PRIu64 "\n", __func__, page);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        memset(iobuf, 0xff, 0x200);
 | 
					        memset(iobuf, 0xff, 0x200);
 | 
				
			||||||
        i = (addr & ~0x1ff) + 0x200;
 | 
					        i = (addr & ~0x1ff) + 0x200;
 | 
				
			||||||
        for (addr += ((PAGE_SIZE + OOB_SIZE) << s->erase_shift) - 0x200;
 | 
					        for (addr += ((PAGE_SIZE + OOB_SIZE) << s->erase_shift) - 0x200;
 | 
				
			||||||
                        i < addr; i += 0x200)
 | 
					                        i < addr; i += 0x200)
 | 
				
			||||||
            if (bdrv_write(s->bdrv, i >> 9, iobuf, 1) == -1)
 | 
					            if (bdrv_write(s->bdrv, i >> 9, iobuf, 1) < 0) {
 | 
				
			||||||
                printf("%s: write error in sector %" PRIu64 "\n",
 | 
					                printf("%s: write error in sector %" PRIu64 "\n",
 | 
				
			||||||
                       __func__, i >> 9);
 | 
					                       __func__, i >> 9);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        page = i >> 9;
 | 
					        page = i >> 9;
 | 
				
			||||||
        if (bdrv_read(s->bdrv, page, iobuf, 1) == -1)
 | 
					        if (bdrv_read(s->bdrv, page, iobuf, 1) < 0) {
 | 
				
			||||||
            printf("%s: read error in sector %" PRIu64 "\n", __func__, page);
 | 
					            printf("%s: read error in sector %" PRIu64 "\n", __func__, page);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
        memset(iobuf, 0xff, ((addr - 1) & 0x1ff) + 1);
 | 
					        memset(iobuf, 0xff, ((addr - 1) & 0x1ff) + 1);
 | 
				
			||||||
        if (bdrv_write(s->bdrv, page, iobuf, 1) == -1)
 | 
					        if (bdrv_write(s->bdrv, page, iobuf, 1) < 0) {
 | 
				
			||||||
            printf("%s: write error in sector %" PRIu64 "\n", __func__, page);
 | 
					            printf("%s: write error in sector %" PRIu64 "\n", __func__, page);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void glue(nand_blk_load_, PAGE_SIZE)(NANDFlashState *s,
 | 
					static void glue(nand_blk_load_, PAGE_SIZE)(NANDFlashState *s,
 | 
				
			||||||
@ -740,18 +748,20 @@ static void glue(nand_blk_load_, PAGE_SIZE)(NANDFlashState *s,
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    if (s->bdrv) {
 | 
					    if (s->bdrv) {
 | 
				
			||||||
        if (s->mem_oob) {
 | 
					        if (s->mem_oob) {
 | 
				
			||||||
            if (bdrv_read(s->bdrv, SECTOR(addr), s->io, PAGE_SECTORS) == -1)
 | 
					            if (bdrv_read(s->bdrv, SECTOR(addr), s->io, PAGE_SECTORS) < 0) {
 | 
				
			||||||
                printf("%s: read error in sector %" PRIu64 "\n",
 | 
					                printf("%s: read error in sector %" PRIu64 "\n",
 | 
				
			||||||
                                __func__, SECTOR(addr));
 | 
					                                __func__, SECTOR(addr));
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
            memcpy(s->io + SECTOR_OFFSET(s->addr) + PAGE_SIZE,
 | 
					            memcpy(s->io + SECTOR_OFFSET(s->addr) + PAGE_SIZE,
 | 
				
			||||||
                            s->storage + (PAGE(s->addr) << OOB_SHIFT),
 | 
					                            s->storage + (PAGE(s->addr) << OOB_SHIFT),
 | 
				
			||||||
                            OOB_SIZE);
 | 
					                            OOB_SIZE);
 | 
				
			||||||
            s->ioaddr = s->io + SECTOR_OFFSET(s->addr) + offset;
 | 
					            s->ioaddr = s->io + SECTOR_OFFSET(s->addr) + offset;
 | 
				
			||||||
        } else {
 | 
					        } else {
 | 
				
			||||||
            if (bdrv_read(s->bdrv, PAGE_START(addr) >> 9,
 | 
					            if (bdrv_read(s->bdrv, PAGE_START(addr) >> 9,
 | 
				
			||||||
                                    s->io, (PAGE_SECTORS + 2)) == -1)
 | 
					                                    s->io, (PAGE_SECTORS + 2)) < 0) {
 | 
				
			||||||
                printf("%s: read error in sector %" PRIu64 "\n",
 | 
					                printf("%s: read error in sector %" PRIu64 "\n",
 | 
				
			||||||
                                __func__, PAGE_START(addr) >> 9);
 | 
					                                __func__, PAGE_START(addr) >> 9);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
            s->ioaddr = s->io + (PAGE_START(addr) & 0x1ff) + offset;
 | 
					            s->ioaddr = s->io + (PAGE_START(addr) & 0x1ff) + offset;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    } else {
 | 
					    } else {
 | 
				
			||||||
 | 
				
			|||||||
@ -351,7 +351,7 @@ static inline int onenand_erase(OneNANDState *s, int sec, int num)
 | 
				
			|||||||
    for (; num > 0; num--, sec++) {
 | 
					    for (; num > 0; num--, sec++) {
 | 
				
			||||||
        if (s->bdrv_cur) {
 | 
					        if (s->bdrv_cur) {
 | 
				
			||||||
            int erasesec = s->secs_cur + (sec >> 5);
 | 
					            int erasesec = s->secs_cur + (sec >> 5);
 | 
				
			||||||
            if (bdrv_write(s->bdrv_cur, sec, blankbuf, 1)) {
 | 
					            if (bdrv_write(s->bdrv_cur, sec, blankbuf, 1) < 0) {
 | 
				
			||||||
                goto fail;
 | 
					                goto fail;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            if (bdrv_read(s->bdrv_cur, erasesec, tmpbuf, 1) < 0) {
 | 
					            if (bdrv_read(s->bdrv_cur, erasesec, tmpbuf, 1) < 0) {
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										16
									
								
								hw/sd.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								hw/sd.c
									
									
									
									
									
								
							@ -1407,7 +1407,7 @@ static void sd_blk_read(SDState *sd, uint64_t addr, uint32_t len)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    DPRINTF("sd_blk_read: addr = 0x%08llx, len = %d\n",
 | 
					    DPRINTF("sd_blk_read: addr = 0x%08llx, len = %d\n",
 | 
				
			||||||
            (unsigned long long) addr, len);
 | 
					            (unsigned long long) addr, len);
 | 
				
			||||||
    if (!sd->bdrv || bdrv_read(sd->bdrv, addr >> 9, sd->buf, 1) == -1) {
 | 
					    if (!sd->bdrv || bdrv_read(sd->bdrv, addr >> 9, sd->buf, 1) < 0) {
 | 
				
			||||||
        fprintf(stderr, "sd_blk_read: read error on host side\n");
 | 
					        fprintf(stderr, "sd_blk_read: read error on host side\n");
 | 
				
			||||||
        return;
 | 
					        return;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@ -1415,7 +1415,7 @@ static void sd_blk_read(SDState *sd, uint64_t addr, uint32_t len)
 | 
				
			|||||||
    if (end > (addr & ~511) + 512) {
 | 
					    if (end > (addr & ~511) + 512) {
 | 
				
			||||||
        memcpy(sd->data, sd->buf + (addr & 511), 512 - (addr & 511));
 | 
					        memcpy(sd->data, sd->buf + (addr & 511), 512 - (addr & 511));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if (bdrv_read(sd->bdrv, end >> 9, sd->buf, 1) == -1) {
 | 
					        if (bdrv_read(sd->bdrv, end >> 9, sd->buf, 1) < 0) {
 | 
				
			||||||
            fprintf(stderr, "sd_blk_read: read error on host side\n");
 | 
					            fprintf(stderr, "sd_blk_read: read error on host side\n");
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
@ -1429,30 +1429,32 @@ static void sd_blk_write(SDState *sd, uint64_t addr, uint32_t len)
 | 
				
			|||||||
    uint64_t end = addr + len;
 | 
					    uint64_t end = addr + len;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if ((addr & 511) || len < 512)
 | 
					    if ((addr & 511) || len < 512)
 | 
				
			||||||
        if (!sd->bdrv || bdrv_read(sd->bdrv, addr >> 9, sd->buf, 1) == -1) {
 | 
					        if (!sd->bdrv || bdrv_read(sd->bdrv, addr >> 9, sd->buf, 1) < 0) {
 | 
				
			||||||
            fprintf(stderr, "sd_blk_write: read error on host side\n");
 | 
					            fprintf(stderr, "sd_blk_write: read error on host side\n");
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (end > (addr & ~511) + 512) {
 | 
					    if (end > (addr & ~511) + 512) {
 | 
				
			||||||
        memcpy(sd->buf + (addr & 511), sd->data, 512 - (addr & 511));
 | 
					        memcpy(sd->buf + (addr & 511), sd->data, 512 - (addr & 511));
 | 
				
			||||||
        if (bdrv_write(sd->bdrv, addr >> 9, sd->buf, 1) == -1) {
 | 
					        if (bdrv_write(sd->bdrv, addr >> 9, sd->buf, 1) < 0) {
 | 
				
			||||||
            fprintf(stderr, "sd_blk_write: write error on host side\n");
 | 
					            fprintf(stderr, "sd_blk_write: write error on host side\n");
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if (bdrv_read(sd->bdrv, end >> 9, sd->buf, 1) == -1) {
 | 
					        if (bdrv_read(sd->bdrv, end >> 9, sd->buf, 1) < 0) {
 | 
				
			||||||
            fprintf(stderr, "sd_blk_write: read error on host side\n");
 | 
					            fprintf(stderr, "sd_blk_write: read error on host side\n");
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        memcpy(sd->buf, sd->data + 512 - (addr & 511), end & 511);
 | 
					        memcpy(sd->buf, sd->data + 512 - (addr & 511), end & 511);
 | 
				
			||||||
        if (bdrv_write(sd->bdrv, end >> 9, sd->buf, 1) == -1)
 | 
					        if (bdrv_write(sd->bdrv, end >> 9, sd->buf, 1) < 0) {
 | 
				
			||||||
            fprintf(stderr, "sd_blk_write: write error on host side\n");
 | 
					            fprintf(stderr, "sd_blk_write: write error on host side\n");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    } else {
 | 
					    } else {
 | 
				
			||||||
        memcpy(sd->buf + (addr & 511), sd->data, len);
 | 
					        memcpy(sd->buf + (addr & 511), sd->data, len);
 | 
				
			||||||
        if (!sd->bdrv || bdrv_write(sd->bdrv, addr >> 9, sd->buf, 1) == -1)
 | 
					        if (!sd->bdrv || bdrv_write(sd->bdrv, addr >> 9, sd->buf, 1) < 0) {
 | 
				
			||||||
            fprintf(stderr, "sd_blk_write: write error on host side\n");
 | 
					            fprintf(stderr, "sd_blk_write: write error on host side\n");
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define BLK_READ_BLOCK(a, len)	sd_blk_read(sd, a, len)
 | 
					#define BLK_READ_BLOCK(a, len)	sd_blk_read(sd, a, len)
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user