.. | .. |
---|
1 | | -/* |
---|
2 | | - * Copyright (C) 2015-2017 Netronome Systems, Inc. |
---|
3 | | - * |
---|
4 | | - * This software is dual licensed under the GNU General License Version 2, |
---|
5 | | - * June 1991 as shown in the file COPYING in the top-level directory of this |
---|
6 | | - * source tree or the BSD 2-Clause License provided below. You have the |
---|
7 | | - * option to license this software under the complete terms of either license. |
---|
8 | | - * |
---|
9 | | - * The BSD 2-Clause License: |
---|
10 | | - * |
---|
11 | | - * Redistribution and use in source and binary forms, with or |
---|
12 | | - * without modification, are permitted provided that the following |
---|
13 | | - * conditions are met: |
---|
14 | | - * |
---|
15 | | - * 1. Redistributions of source code must retain the above |
---|
16 | | - * copyright notice, this list of conditions and the following |
---|
17 | | - * disclaimer. |
---|
18 | | - * |
---|
19 | | - * 2. Redistributions in binary form must reproduce the above |
---|
20 | | - * copyright notice, this list of conditions and the following |
---|
21 | | - * disclaimer in the documentation and/or other materials |
---|
22 | | - * provided with the distribution. |
---|
23 | | - * |
---|
24 | | - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
---|
25 | | - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
---|
26 | | - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
---|
27 | | - * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS |
---|
28 | | - * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
---|
29 | | - * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN |
---|
30 | | - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |
---|
31 | | - * SOFTWARE. |
---|
32 | | - */ |
---|
| 1 | +// SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) |
---|
| 2 | +/* Copyright (C) 2015-2018 Netronome Systems, Inc. */ |
---|
33 | 3 | |
---|
34 | 4 | /* |
---|
35 | 5 | * nfp_target.c |
---|
.. | .. |
---|
39 | 9 | * Francois H. Theron <francois.theron@netronome.com> |
---|
40 | 10 | */ |
---|
41 | 11 | |
---|
| 12 | +#define pr_fmt(fmt) "NFP target: " fmt |
---|
| 13 | + |
---|
42 | 14 | #include <linux/bitops.h> |
---|
| 15 | +#include <linux/kernel.h> |
---|
| 16 | +#include <linux/printk.h> |
---|
43 | 17 | |
---|
44 | 18 | #include "nfp_cpp.h" |
---|
45 | 19 | |
---|
.. | .. |
---|
733 | 707 | u32 imb; |
---|
734 | 708 | int err; |
---|
735 | 709 | |
---|
736 | | - if (target < 0 || target >= 16) |
---|
| 710 | + if (target < 0 || target >= 16) { |
---|
| 711 | + pr_err("Invalid CPP target: %d\n", target); |
---|
737 | 712 | return -EINVAL; |
---|
| 713 | + } |
---|
738 | 714 | |
---|
739 | 715 | if (island == 0) { |
---|
740 | 716 | /* Already translated */ |
---|
.. | .. |
---|
753 | 729 | err = nfp_cppat_addr_encode(cpp_target_address, island, target, |
---|
754 | 730 | ((imb >> 13) & 7), ((imb >> 12) & 1), |
---|
755 | 731 | ((imb >> 6) & 0x3f), ((imb >> 0) & 0x3f)); |
---|
756 | | - if (err) |
---|
| 732 | + if (err) { |
---|
| 733 | + pr_err("Can't encode CPP address: %d\n", err); |
---|
757 | 734 | return err; |
---|
| 735 | + } |
---|
758 | 736 | |
---|
759 | 737 | *cpp_target_id = NFP_CPP_ID(target, |
---|
760 | 738 | NFP_CPP_ID_ACTION_of(cpp_island_id), |
---|