xref: /dpdk/drivers/net/enic/base/vnic_intr.c (revision 04e8ec74192ae4bc537e4854410551255bf85cf5)
12e99ea80SHyong Youb Kim /* SPDX-License-Identifier: BSD-3-Clause
22e99ea80SHyong Youb Kim  * Copyright 2008-2017 Cisco Systems, Inc.  All rights reserved.
372f3de30SBruce Richardson  * Copyright 2007 Nuova Systems, Inc.  All rights reserved.
472f3de30SBruce Richardson  */
572f3de30SBruce Richardson 
672f3de30SBruce Richardson #include "vnic_dev.h"
772f3de30SBruce Richardson #include "vnic_intr.h"
872f3de30SBruce Richardson 
vnic_intr_free(struct vnic_intr * intr)972f3de30SBruce Richardson void vnic_intr_free(struct vnic_intr *intr)
1072f3de30SBruce Richardson {
1172f3de30SBruce Richardson 	intr->ctrl = NULL;
1272f3de30SBruce Richardson }
1372f3de30SBruce Richardson 
vnic_intr_alloc(struct vnic_dev * vdev,struct vnic_intr * intr,unsigned int index)1472f3de30SBruce Richardson int vnic_intr_alloc(struct vnic_dev *vdev, struct vnic_intr *intr,
1572f3de30SBruce Richardson 	unsigned int index)
1672f3de30SBruce Richardson {
1772f3de30SBruce Richardson 	intr->index = index;
1872f3de30SBruce Richardson 	intr->vdev = vdev;
1972f3de30SBruce Richardson 
2072f3de30SBruce Richardson 	intr->ctrl = vnic_dev_get_res(vdev, RES_TYPE_INTR_CTRL, index);
2172f3de30SBruce Richardson 	if (!intr->ctrl) {
2272f3de30SBruce Richardson 		pr_err("Failed to hook INTR[%d].ctrl resource\n", index);
2372f3de30SBruce Richardson 		return -EINVAL;
2472f3de30SBruce Richardson 	}
2572f3de30SBruce Richardson 
2672f3de30SBruce Richardson 	return 0;
2772f3de30SBruce Richardson }
2872f3de30SBruce Richardson 
vnic_intr_init(struct vnic_intr * intr,uint32_t coalescing_timer,unsigned int coalescing_type,unsigned int mask_on_assertion)29*04e8ec74SJohn Daley void vnic_intr_init(struct vnic_intr *intr, uint32_t coalescing_timer,
3072f3de30SBruce Richardson 	unsigned int coalescing_type, unsigned int mask_on_assertion)
3172f3de30SBruce Richardson {
3272f3de30SBruce Richardson 	vnic_intr_coalescing_timer_set(intr, coalescing_timer);
3372f3de30SBruce Richardson 	iowrite32(coalescing_type, &intr->ctrl->coalescing_type);
3472f3de30SBruce Richardson 	iowrite32(mask_on_assertion, &intr->ctrl->mask_on_assertion);
3572f3de30SBruce Richardson 	iowrite32(0, &intr->ctrl->int_credits);
3672f3de30SBruce Richardson }
3772f3de30SBruce Richardson 
vnic_intr_coalescing_timer_set(struct vnic_intr * intr,uint32_t coalescing_timer)3872f3de30SBruce Richardson void vnic_intr_coalescing_timer_set(struct vnic_intr *intr,
39*04e8ec74SJohn Daley 	uint32_t coalescing_timer)
4072f3de30SBruce Richardson {
4172f3de30SBruce Richardson 	iowrite32(vnic_dev_intr_coal_timer_usec_to_hw(intr->vdev,
4272f3de30SBruce Richardson 		coalescing_timer), &intr->ctrl->coalescing_timer);
4372f3de30SBruce Richardson }
4472f3de30SBruce Richardson 
vnic_intr_clean(struct vnic_intr * intr)4572f3de30SBruce Richardson void vnic_intr_clean(struct vnic_intr *intr)
4672f3de30SBruce Richardson {
4772f3de30SBruce Richardson 	iowrite32(0, &intr->ctrl->int_credits);
4872f3de30SBruce Richardson }
49