tech-kern archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
Re: ataraid(4) missing disk handling
On Mon, Mar 10, 2025 at 04:43:30PM +0200, Andrius V wrote:
> Taylor has a good analysis and explanation of the issue
> https://mail-index.netbsd.org/netbsd-bugs/2024/03/26/msg082202.html,
> which I also noticed by testing ATA RAID setup on VIA controllers.
> [...]
Good analysis.
> Given that three statuses are defined for adi_status
> (https://nxr.netbsd.org/xref/src/sys/dev/ata/ata_raidvar.h#75), I
> probably need to check if any of the flags are defined ((adi_status &
> (ADI_S_ONLINE | ADI_S_ASSIGNED | ADI_S_SPARE)) instead
> (https://netbsd.org/~andvar/ata_raid_fix2.diff).
The first part seems fine. Although I didn't look at what the difference
between vn_bdev_open() vs. the deleted code is.
In the second part this bit is weird for me to read:
+ else
+ vp = NULL;
if (vp == NULL) {
I'd write it as:
- vp = ata_raid_disk_vnode_find(adi);
+ vp = NULL;
+ if (adi->adi_status &
+ (ADI_S_ONLINE | ADI_S_ASSIGNED | ADI_S_SPARE))
if (vp == NULL) {
/*
* XXX This is bogus. We should just mark the
But Taylor seemed to be fine with it if I remember the discussion on ICB
correctly. A matter of style I guess.
> Another alternative is to check that adi->adi_dev IS NULL as Taylor
> proposed in his analysis thread.
But that proposal never explained how an adv with adi->adi_dev==NULL ended
up on the ataraid_disk_vnode_list which isn't supposed to happen!
--chris
Home |
Main Index |
Thread Index |
Old Index