Blame SOURCES/cups-1.6.3-page-count.patch

87cf9a
--- cups-1.6.3.rsac.old/backend/snmp-supplies.c	2013-06-06 18:12:52.000000000 -0700
87cf9a
+++ cups-1.6.3.rsac.new/backend/snmp-supplies.c	2017-02-20 15:57:28.420977310 -0800
87cf9a
@@ -90,6 +90,8 @@ static backend_supplies_t supplies[CUPS_
87cf9a
 					/* Supply information */
87cf9a
 static int		supply_state = -1;
87cf9a
 					/* Supply state info */
87cf9a
+static int              use_snmp_pages = 1;
87cf9a
+                                        /* Report pages used or not */
87cf9a
 
87cf9a
 static const int	hrDeviceDescr[] =
87cf9a
 			{ CUPS_OID_hrDeviceDescr, 1, -1 };
87cf9a
@@ -410,16 +412,21 @@ backendSNMPSupplies(
87cf9a
 
87cf9a
     if (page_count)
87cf9a
     {
87cf9a
-      if (!_cupsSNMPWrite(snmp_fd, addr, CUPS_SNMP_VERSION_1,
87cf9a
-			 _cupsSNMPDefaultCommunity(), CUPS_ASN1_GET_REQUEST, 1,
87cf9a
-			 prtMarkerLifeCount))
87cf9a
-	return (-1);
87cf9a
-
87cf9a
-      if (!_cupsSNMPRead(snmp_fd, &packet, CUPS_SUPPLY_TIMEOUT) ||
87cf9a
-	  packet.object_type != CUPS_ASN1_COUNTER)
87cf9a
-	return (-1);
87cf9a
-
87cf9a
-      *page_count = packet.object_value.counter;
87cf9a
+      if (use_snmp_pages)
87cf9a
+      {
87cf9a
+        if (!_cupsSNMPWrite(snmp_fd, addr, CUPS_SNMP_VERSION_1,
87cf9a
+                            _cupsSNMPDefaultCommunity(), CUPS_ASN1_GET_REQUEST, 1,
87cf9a
+                            prtMarkerLifeCount))
87cf9a
+          return (-1);
87cf9a
+
87cf9a
+        if (!_cupsSNMPRead(snmp_fd, &packet, CUPS_SUPPLY_TIMEOUT) ||
87cf9a
+            packet.object_type != CUPS_ASN1_COUNTER)
87cf9a
+          return (-1);
87cf9a
+        
87cf9a
+        *page_count = packet.object_value.counter;
87cf9a
+      }
87cf9a
+      else
87cf9a
+        *page_count = 0;
87cf9a
     }
87cf9a
 
87cf9a
     return (0);
87cf9a
@@ -521,6 +528,12 @@ backend_init_supplies(
87cf9a
       quirks |= CUPS_SNMP_CAPACITY;
87cf9a
   }
87cf9a
 
87cf9a
+  if ((ppdattr = ppdFindAttr(ppd, "cupsSNMPPages", NULL)) != NULL )
87cf9a
+  {
87cf9a
+    if (_cups_strcasecmp(ppdattr->value, "true"))
87cf9a
+      use_snmp_pages = 0;
87cf9a
+  }
87cf9a
+
87cf9a
   ppdClose(ppd);
87cf9a
 
87cf9a
  /*