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