Can not build kernel with modular ata and ATA_CAM

Henri Hennebert hlh at restart.be
Mon Jun 25 10:04:37 UTC 2012


On 06/25/2012 10:50, Mitya wrote:
> My kernel options:
>
> # Bus support.
> device          acpi
> device          pci
>
> # Modular ATA
> device          atadisk         # ATA disk drives
> device          atacore         # Core ATA functionality
> device          atapci          # PCI bus support; only generic chipset
> support
> device          ataintel        # Intel
>
> options         ATA_CAM         # Handle legacy controllers with CAM
> options         ATA_STATIC_ID   # Static device numbering
>
> # ATA/SCSI peripherals
> device          scbus           # SCSI bus (required for ATA/SCSI)
> device          da              # Direct Access (disks)
> device          pass            # Passthrough device (direct ATA/SCSI
> access)

 From /usr/src/sys/conf/NOTES:

# ATA_CAM:              Turn ata(4) subsystem controller drivers into cam(4)
#                       interface modules. This deprecates all ata(4)
#                       peripheral device drivers (atadisk, ataraid, 
atapicd,
#                       atapifd, atapist, atapicam) and all user-level APIs.
#                       cam(4) drivers and APIs will be connected instead.


So you must remove 'device          atadisk'

Henri


>
> make's output:
>
> ata-disk.o: In function `ad_init':
> ata-disk.c:(.text+0x7d): undefined reference to `ata_setmode'
> ata-disk.c:(.text+0x95): undefined reference to `ata_wc'
> ata-disk.c:(.text+0xc9): undefined reference to `ata_controlcmd'
> ata-disk.c:(.text+0x11b): undefined reference to `ata_controlcmd'
> ata-disk.c:(.text+0x16d): undefined reference to `ata_controlcmd'
> ata-disk.c:(.text+0x1b6): undefined reference to `ata_controlcmd'
> ata-disk.o: In function `ad_shutdown':
> ata-disk.c:(.text+0x258): undefined reference to `ata_controlcmd'
> ata-disk.o: In function `ad_detach':
> ata-disk.c:(.text+0x479): undefined reference to `ata_fail_requests'
> ata-disk.o: In function `ad_dump':
> ata-disk.c:(.text+0x861): undefined reference to `ata_drop_requests'
> ata-disk.c:(.text+0x921): undefined reference to `ata_controlcmd'
> ata-disk.o: In function `ad_attach':
> ata-disk.c:(.text+0xa40): undefined reference to `ata_setmax'
> ata-disk.c:(.text+0xb62): undefined reference to `ata_satarev2str'
> ata-disk.c:(.text+0xba7): undefined reference to `ata_unit2str'
> ata-disk.c:(.text+0xfff): undefined reference to `ata_queue_request'
> ata-disk.c:(.text+0x131e): undefined reference to `ata_queue_request'
> ata-disk.c:(.text+0x1340): undefined reference to `ata_getparam'
> ata-disk.o: In function `ad_spindown':
> ata-disk.c:(.text+0x539): undefined reference to `ata_queue_request'
> ata-disk.o: In function `ad_ioctl':
> ata-disk.c:(.text+0x5a4): undefined reference to `ata_device_ioctl'
> ata-disk.o: In function `ad_strategy':
> ata-disk.c:(.text+0x6c7): undefined reference to `ata_queue_request'
> *** [kernel] Error code 1
>
> I found differences in ata-all.c and ata-all.h
>
> In ata-all.c:
> #ifndef ATA_CAM
> void
> ata_setmode(device_t dev)
> {
>
> But, in ata-all.h:
> void ata_setmode(device_t dev);
>
> without any #ifdef or #ifndef
>
>
>
>
>
>
>
> _______________________________________________
> freebsd-stable at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-stable
> To unsubscribe, send any mail to "freebsd-stable-unsubscribe at freebsd.org"
>




More information about the freebsd-stable mailing list