aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ide/ide-taskfile.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ide/ide-taskfile.c')
-rw-r--r--drivers/ide/ide-taskfile.c109
1 files changed, 0 insertions, 109 deletions
diff --git a/drivers/ide/ide-taskfile.c b/drivers/ide/ide-taskfile.c
index 7ffe9004a4d6..487b18b3ebae 100644
--- a/drivers/ide/ide-taskfile.c
+++ b/drivers/ide/ide-taskfile.c
@@ -726,112 +726,3 @@ abort:
726 return err; 726 return err;
727} 727}
728#endif 728#endif
729
730int ide_cmd_ioctl (ide_drive_t *drive, unsigned int cmd, unsigned long arg)
731{
732 u8 *buf = NULL;
733 int bufsize = 0, err = 0;
734 u8 args[4], xfer_rate = 0;
735 ide_task_t tfargs;
736 struct ide_taskfile *tf = &tfargs.tf;
737 u16 *id = drive->id;
738
739 if (NULL == (void *) arg) {
740 struct request *rq;
741
742 rq = blk_get_request(drive->queue, READ, __GFP_WAIT);
743 rq->cmd_type = REQ_TYPE_ATA_TASKFILE;
744 err = blk_execute_rq(drive->queue, NULL, rq, 0);
745 blk_put_request(rq);
746
747 return err;
748 }
749
750 if (copy_from_user(args, (void __user *)arg, 4))
751 return -EFAULT;
752
753 memset(&tfargs, 0, sizeof(ide_task_t));
754 tf->feature = args[2];
755 if (args[0] == ATA_CMD_SMART) {
756 tf->nsect = args[3];
757 tf->lbal = args[1];
758 tf->lbam = 0x4f;
759 tf->lbah = 0xc2;
760 tfargs.tf_flags = IDE_TFLAG_OUT_TF | IDE_TFLAG_IN_NSECT;
761 } else {
762 tf->nsect = args[1];
763 tfargs.tf_flags = IDE_TFLAG_OUT_FEATURE |
764 IDE_TFLAG_OUT_NSECT | IDE_TFLAG_IN_NSECT;
765 }
766 tf->command = args[0];
767 tfargs.data_phase = args[3] ? TASKFILE_IN : TASKFILE_NO_DATA;
768
769 if (args[3]) {
770 tfargs.tf_flags |= IDE_TFLAG_IO_16BIT;
771 bufsize = SECTOR_SIZE * args[3];
772 buf = kzalloc(bufsize, GFP_KERNEL);
773 if (buf == NULL)
774 return -ENOMEM;
775 }
776
777 if (tf->command == ATA_CMD_SET_FEATURES &&
778 tf->feature == SETFEATURES_XFER &&
779 tf->nsect >= XFER_SW_DMA_0 &&
780 (id[ATA_ID_UDMA_MODES] ||
781 id[ATA_ID_MWDMA_MODES] ||
782 id[ATA_ID_SWDMA_MODES])) {
783 xfer_rate = args[1];
784 if (tf->nsect > XFER_UDMA_2 && !eighty_ninty_three(drive)) {
785 printk(KERN_WARNING "%s: UDMA speeds >UDMA33 cannot "
786 "be set\n", drive->name);
787 goto abort;
788 }
789 }
790
791 err = ide_raw_taskfile(drive, &tfargs, buf, args[3]);
792
793 args[0] = tf->status;
794 args[1] = tf->error;
795 args[2] = tf->nsect;
796
797 if (!err && xfer_rate) {
798 /* active-retuning-calls future */
799 ide_set_xfer_rate(drive, xfer_rate);
800 ide_driveid_update(drive);
801 }
802abort:
803 if (copy_to_user((void __user *)arg, &args, 4))
804 err = -EFAULT;
805 if (buf) {
806 if (copy_to_user((void __user *)(arg + 4), buf, bufsize))
807 err = -EFAULT;
808 kfree(buf);
809 }
810 return err;
811}
812
813int ide_task_ioctl (ide_drive_t *drive, unsigned int cmd, unsigned long arg)
814{
815 void __user *p = (void __user *)arg;
816 int err = 0;
817 u8 args[7];
818 ide_task_t task;
819
820 if (copy_from_user(args, p, 7))
821 return -EFAULT;
822
823 memset(&task, 0, sizeof(task));
824 memcpy(&task.tf_array[7], &args[1], 6);
825 task.tf.command = args[0];
826 task.tf_flags = IDE_TFLAG_TF | IDE_TFLAG_DEVICE;
827
828 err = ide_no_data_taskfile(drive, &task);
829
830 args[0] = task.tf.command;
831 memcpy(&args[1], &task.tf_array[7], 6);
832
833 if (copy_to_user(p, args, 7))
834 err = -EFAULT;
835
836 return err;
837}