blob: 6a68e8d93309ab085bae60dd2dc5531ce1f03765 [file] [log] [blame]
Rasesh Mody8b230ed2010-08-23 20:24:12 -07001/*
2 * Linux network driver for Brocade Converged Network Adapter.
3 *
4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms of the GNU General Public License (GPL) Version 2 as
6 * published by the Free Software Foundation
7 *
8 * This program is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 * General Public License for more details.
12 */
13/*
14 * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
15 * All rights reserved
16 * www.brocade.com
17 */
18#include <linux/firmware.h>
stephen hemmingere1e09182012-01-04 13:02:24 +000019#include "bnad.h"
Rasesh Mody1bf9fd702011-09-27 10:39:07 +000020#include "bfi.h"
Rasesh Mody8b230ed2010-08-23 20:24:12 -070021#include "cna.h"
22
23const struct firmware *bfi_fw;
Rasesh Mody1bf9fd702011-09-27 10:39:07 +000024static u32 *bfi_image_ct_cna, *bfi_image_ct2_cna;
25static u32 bfi_image_ct_cna_size, bfi_image_ct2_cna_size;
Rasesh Mody8b230ed2010-08-23 20:24:12 -070026
Rasesh Modyb7ee31c52010-10-05 15:46:05 +000027static u32 *
Rasesh Mody8b230ed2010-08-23 20:24:12 -070028cna_read_firmware(struct pci_dev *pdev, u32 **bfi_image,
29 u32 *bfi_image_size, char *fw_name)
30{
31 const struct firmware *fw;
32
33 if (request_firmware(&fw, fw_name, &pdev->dev)) {
34 pr_alert("Can't locate firmware %s\n", fw_name);
35 goto error;
36 }
37
38 *bfi_image = (u32 *)fw->data;
39 *bfi_image_size = fw->size/sizeof(u32);
40 bfi_fw = fw;
41
42 return *bfi_image;
43error:
44 return NULL;
45}
46
47u32 *
48cna_get_firmware_buf(struct pci_dev *pdev)
49{
Rasesh Mody1bf9fd702011-09-27 10:39:07 +000050 if (pdev->device == BFA_PCI_DEVICE_ID_CT2) {
51 if (bfi_image_ct2_cna_size == 0)
52 cna_read_firmware(pdev, &bfi_image_ct2_cna,
53 &bfi_image_ct2_cna_size, CNA_FW_FILE_CT2);
54 return bfi_image_ct2_cna;
55 } else if (bfa_asic_id_ct(pdev->device)) {
56 if (bfi_image_ct_cna_size == 0)
57 cna_read_firmware(pdev, &bfi_image_ct_cna,
58 &bfi_image_ct_cna_size, CNA_FW_FILE_CT);
59 return bfi_image_ct_cna;
60 }
61
62 return NULL;
Rasesh Mody8b230ed2010-08-23 20:24:12 -070063}
64
65u32 *
Rasesh Mody1bf9fd702011-09-27 10:39:07 +000066bfa_cb_image_get_chunk(enum bfi_asic_gen asic_gen, u32 off)
Rasesh Mody8b230ed2010-08-23 20:24:12 -070067{
Rasesh Mody1bf9fd702011-09-27 10:39:07 +000068 switch (asic_gen) {
69 case BFI_ASIC_GEN_CT:
Joe Perches64699332012-06-04 12:44:16 +000070 return (bfi_image_ct_cna + off);
Rasesh Mody1bf9fd702011-09-27 10:39:07 +000071 break;
72 case BFI_ASIC_GEN_CT2:
Joe Perches64699332012-06-04 12:44:16 +000073 return (bfi_image_ct2_cna + off);
Rasesh Mody1bf9fd702011-09-27 10:39:07 +000074 break;
75 default:
76 return NULL;
77 }
Rasesh Mody8b230ed2010-08-23 20:24:12 -070078}
79
80u32
Rasesh Mody1bf9fd702011-09-27 10:39:07 +000081bfa_cb_image_get_size(enum bfi_asic_gen asic_gen)
Rasesh Mody8b230ed2010-08-23 20:24:12 -070082{
Rasesh Mody1bf9fd702011-09-27 10:39:07 +000083 switch (asic_gen) {
84 case BFI_ASIC_GEN_CT:
85 return bfi_image_ct_cna_size;
86 break;
87 case BFI_ASIC_GEN_CT2:
88 return bfi_image_ct2_cna_size;
89 break;
90 default:
91 return 0;
92 }
Rasesh Mody8b230ed2010-08-23 20:24:12 -070093}