On Thu, 13 Jun 2013 20:55:15 -0700
Jeff Kirsher <[email protected]> wrote:

> +
> +char i40e_driver_name[] = "i40e";

Obviously const

+/* Helper macros for reading the stats registers
+ *
+ * Since the device stats are not reset at PFReset, they likely will not
+ * be zeroed when the driver starts.  We'll save the first values read
+ * and use them as offsets to be subtracted from the raw values in order
+ * to report stats that count from zero.
+ */
+#define I40E_STAT_UPDATE48(hireg, loreg, offset_loaded, offset, stat)     \
+do {                                                                      \
+       u64 new_data;                                                     \
+       new_data = rd64(hw, (loreg));                                     \
+       if (!(offset_loaded))                                             \
+               (offset) = new_data;                                      \
+       if (likely(new_data >= (offset)))                                 \
+               (stat) = new_data - (offset);                             \
+       else                                                              \
+               (stat) = (new_data + ((u64)1 << 48)) - (offset);          \
+       (stat) &= 0xFFFFFFFFFFFFULL;                                      \
+} while (0)

Macro's suck, this could just as well be a function
or maybe a macro that calls function (and go ahead and do string manipulation)




------------------------------------------------------------------------------
This SF.net email is sponsored by Windows:

Build for Windows Store.

http://p.sf.net/sfu/windows-dev2dev
_______________________________________________
E1000-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/e1000-devel
To learn more about Intel&#174; Ethernet, visit 
http://communities.intel.com/community/wired

Reply via email to