}
 EXPORT_SYMBOL_GPL(sas_execute_internal_abort_single);
 
+int sas_execute_internal_abort_dev(struct domain_device *device,
+                                  unsigned int qid, void *data)
+{
+       return sas_execute_internal_abort(device, SAS_INTERNAL_ABORT_DEV,
+                                         SCSI_NO_TAG, qid, data);
+}
+EXPORT_SYMBOL_GPL(sas_execute_internal_abort_dev);
+
 int sas_execute_tmf(struct domain_device *device, void *parameter,
                    int para_len, int force_phy_id,
                    struct sas_tmf_task *tmf)
 
 /* LLDDs rely on these values */
 enum sas_internal_abort {
        SAS_INTERNAL_ABORT_SINGLE       = 0,
+       SAS_INTERNAL_ABORT_DEV          = 1,
 };
 
 struct sas_internal_abort_task {
 extern struct sas_task *sas_alloc_slow_task(gfp_t flags);
 extern void sas_free_task(struct sas_task *task);
 
+static inline bool sas_is_internal_abort(struct sas_task *task)
+{
+       return task->task_proto == SAS_PROTOCOL_INTERNAL_ABORT;
+}
+
 struct sas_domain_function_template {
        /* The class calls these to notify the LLDD of an event. */
        void (*lldd_port_formed)(struct asd_sas_phy *);
 int sas_execute_internal_abort_single(struct domain_device *device,
                                      u16 tag, unsigned int qid,
                                      void *data);
+int sas_execute_internal_abort_dev(struct domain_device *device,
+                                  unsigned int qid, void *data);
 extern struct scsi_transport_template *
 sas_domain_attach_transport(struct sas_domain_function_template *);
 extern struct device_attribute dev_attr_phy_event_threshold;