Building Python Apps with Hardware Access

The world of programming relies on a concept called abstraction. Different programming languages provide various levels of abstraction, acting as a bridge between the programmer and the hardware. High-level languages like Python hide much of the machine’s complexity. This allows developers to focus on logic and functionality. Python is widely used for its ease and versatility. However, low-level languages offer advantages in specific situations.

Low-level languages sit closer to the hardware, providing fine-grained control over system resources like memory and processor registers. Assembly language, for instance, directly translates human-readable instructions into machine code, the language computers understand. While notoriously intricate, assembly grants programmers unmatched control over how the hardware executes tasks.  Other low-level languages like C and C++ offer a balance between control and readability, allowing programmers to interact with hardware at a more manageable level.

Enhancing Python with Hardware Interaction Through WinDriver

While Python excels in various domains like data science and web development, its higher-level abstraction comes at a cost. When it comes to kernel development, the heart of an operating system, or directly manipulating hardware components, Python isn’t the ideal choice. This is where the power of low-level languages shines.

One might ask, why complicate things by introducing a lower-level language when Python itself seems sufficient? Here’s where the potential of WinDriver Python libraries comes into play. They bridge the gap between the high-level world of Python and the low-level functionalities of the kernel. This allows developers to harness the performance benefits of kernel-level interactions for specific tasks within their Python applications, without abandoning the ease of use and extensive libraries Python offers.

Imagine a Python-based application for image processing. While it excels in image manipulation algorithms, the actual execution might be bottlenecked by the underlying hardware. By utilizing WinDriver, developers can interact with the graphics card’s hardware acceleration features directly from within their Python application. This offloads the computationally intensive tasks to the GPU, significantly improving the processing speed and overall responsiveness of the application.

Beyond Performance: Kernel Access for Enhanced 3D Printing Control

The possibilities extend beyond performance optimization. Kernel-level access through Python libraries unlocks functionalities not readily available in high-level languages. Let’s talk about another example. Consider a Python application for 3D printing. While there are existing libraries for basic control of 3D printers in Python, these might lack precise control over specific functionalities. Kernel-level access offers several advantages: 

  • Fine-tuned Printing Parameters: Low-level code allows for more granular control over printing parameters like nozzle temperature, extrusion speed, and filament feed rate. 
  • Real-time Printer Monitoring:  Kernel-level access grants the application the ability to monitor various sensor readings directly from the 3D printer, such as temperature readings and filament flow sensors
  • Customizable Print Profiles:  Developers can leverage WinDriver to create user-defined print profiles within the Python application. These profiles could contain specific control parameters for different materials or desired print qualities.

By integrating kernel-level functionalities with the user-friendly nature of Python, developers can create powerful 3D printing control and monitoring applications. These applications offer precise control over the printing process, real-time monitoring capabilities, and customizable print profiles, making them valuable tools for both hobbyists and professional 3D printing enthusiasts.

The Future of Integrated Software Development

In conclusion, while Python remains a dominant force in application development, strategically leveraging libraries like WinDriver’s opens doors to a new level of functionality and performance within Python-based applications. By integrating controlled sections of low-level code, developers can unlock the hidden potential of the kernel, enabling Python applications to interact with hardware more directly, perform complex tasks more efficiently, and ultimately deliver a more robust and feature-rich user experience. 

This hybrid approach signifies the future of software development – leveraging the strengths of different languages to create applications that are both powerful and user-friendly.

Want to learn more about WinDriver? Contact our team today.
Download WinDriver for free, and enjoy our 30-day trial.

Device and Driver INFs – A Comprehensive Guide

Operating systems are made to ease the interaction between humans and computers. However, it is not just about convenient file storage and a friendly user interface. One of the basic roles of an operating system is to protect the user from unauthorized and malicious software. In many ways, the kernel is the most sensitive level of the computer. That is why Windows created the INF mechanism. 

Hardware developers (for Windows environment) must be familiar with the INF and digital signature mechanisms, to provide a safe and easy installation. 

What are INFs?

These files are plain text files crucial for installing software and drivers in Windows operating systems. They act as blueprints, providing instructions and details about the installation process. It includes the driver information, installation instructions, and configuration settings. When a new hardware component is connected, like a printer or a sound card, Windows searches for the corresponding INF file to understand how to install the necessary drivers.

This standardized format ensures consistency across different manufacturers and devices, allowing Windows to understand and interpret the information easily. INF files also incorporate basic security measures. They can specify trusted sources for driver files, preventing the installation of potentially harmful software. They can also limit certain actions and modifications, enhancing system stability and integrity.

To authorize the manufacturer of the device INF files are often accompanied by digital signatures. These signatures act like electronic seals, created using cryptographic algorithms and linked to a trusted entity. When Windows encounters an INF file, it verifies the digital signature using the public key of the trusted entity. If the signature is valid, it indicates that the file hasn’t been modified or tampered with since it was signed, ensuring its authenticity and trustworthiness.

Driver and Device INFs

As we understand by now, on Windows, no access to the kernel will be possible without a trusted INF. WinDriver, offering a user-mode driver development toolkit, must gain access to the kernel to perform its magic.

Driver INF provides a bridge between the user and kernel mode. The default driver INF is WinDriver’s named windrvrVVVV (where VVVV=WinDriver’s version). Distributed machines do not have WinDriver installed, so in the case of distribution, your project should have both the device and driver INF installed. Both of them are automatically generated as part of your project. 

Device INF is unique to a particular device, enabling access to it. The device INF can be generated for development and testing purposes only, bound to the default INF, or as part of the distribution package. Both must be installed and enabled for the driver to work properly. Most of the Invalid Handle and device access issues are related to INF issues.

WDREG is another tool developed by WinDriver and is aimed to ease the driver development process. It is a dynamic kernel module loader, allowing you to install and enable (and vice versa) INFs. 

Learn more and experience it yourself in these links.

Contact our team today to learn more about WinDriver.
Download WinDriver for free, and enjoy our 30-day trial.

Scatter-Gather or Contiguous? Understanding DMA Types

In PCIe driver development, DMA (Direct Memory Access) facilitates data transfer between a PCIe device and system memory without involving the CPU. This transfer method significantly improves performance compared to CPU-mediated transfers, as it frees up the CPU for other tasks.

The basic DMA architecture includes 4 steps, defined and managed in the driver:

  1. Allocating a memory region accessible for DMA – This means the region (in the memory) that has specific properties that allow the device to directly read and write from it.
  2. Providing the physical address of the memory region to the device – The device translates this address into a format it understands for its DMA operations.
  3. Initiating the DMA transfer – The device uses its DMA controller to directly transfer data between its internal memory and the allocated memory region on the host system.
  4. Notifying when the transfer is complete – Freeing the allocated space, and processing the data or triggers further actions.

The memory allocation depends on various factors; the type of data transferred, device-memory compatibility, system architecture, and more. The actual free memory that can be allocated for the transfer is perhaps the most critical factor. Sometimes, there is not enough contiguous space to allocate to the DMA. 

Both contiguous and scatter-gather DMA (also: SG) are techniques used in PCIe driver development to efficiently transfer data between a device and system memory, but they differ in how they handle buffer allocation:

Contiguous DMA  – Pages a single segment of the memory, locking it to execute the transfer. Managing the transfer on the device side is easier, but it’s not always possible if sufficient contiguous memory isn’t allocated. This constraint is generally due to fragmentation.

Scatter-Gather DMA – Allocates multiple, potentially non-contiguous blocks of memory. The data fragments residing in memory are managed with a descriptor table, telling the device which data should go where. It is more complex to set up on the driver side as you need to manage the descriptor table.

So, which one is better?

As said, contiguous DMA is easier to program, debug and manage. However, SG DMA can be more effective when the requirements demand data scattered across multiple memory locations, in cases of large data transfers and when contiguous memory is scarce.

Regarding performance and speed, there is no straightforward answer. It depends on the device (and which DMA types the hardware supports), the memory (data patterns and available space) and the driver complexity. We recommend checking different methods, including DMA combined with polling and interrupts. Sometimes the results can be surprising. 

WinDriver, the leading cross-platform driver development toolkit for PCI/PCIe devices offers several tools making the development of both types of DMA easier. As a developer, you will be able to perform kernel operations (including DMA-related) from the user mode. Moreover, we offer an automated generated code based on settings defined in a GUI application (no-code). If you are new to this operation, WinDriver includes free samples of DMA run and tested for industry standard DMA IP Cores from companies such as Intel Altera, AMD Xilinx, Lattice, and more.

Want to learn more about WinDriver? Contact our team today.
Download WinDriver for free, and enjoy our 30-day trial.

Mastering Driver Development for High-Speed PCIe Devices

Nobody likes latency. The need for high speed and precise data transfer arises everywhere, from satellites orbiting space to data centers deep beneath the Earth’s surface. PCIe 7.0 is capable of transferring 128 GT/s, fulfilling the promise to double the I/O bandwidth every 3 years. 

One of the kernel developer’s goals is to utilize the hardware fully. It is not just about making everything work, but also maximizing the product’s potential. 

Optimize PCIe Devices: 4 Key Areas to Address

  • Use DMA – Perhaps the first thing we think of when it comes to data transfer speed is Direct Memory Access.
    DMA allows for direct data transfer between the device and memory, bypassing the CPU. This cuts down on latency and boosts throughput. Although it can be more challenging to set up a DMA mechanism, a properly implemented DMA significantly improves performance and reduces latency.
  • Implement Kernel Plugin – Kernel plugins are chunks of code (performing specific operations) that sit only in the kernel mode. The fact that they run without constantly context-switching with the user mode, makes their loading dynamic and operations faster. This not only affects the speed, but also demands less resources.
  • Optimize your code – A fine code can make all the difference, especially when there are a lot of “moving parts”. Coding an effective interrupt handler, managing multiple queues, optimizing memory access patterns, and other critical components can also enhance the device’s speed.
  • Update your OS version – The benefits of working with the latest version of an operating system do not stop at performance improvement. New versions often include critical security and other bug fixes, and better compatibility, support, and APIs. Research showed that newer versions enhance device performance.

Efficient data transfer with minimal latency is crucial across various applications. Kernel developers aiming to fully utilize their device potential must consider performance enhancement strategies like DMA, implementing Kernel Plugins, optimizing code, and working with an updated operating system. Ultimately contributing to enhanced device performance.

WinDriver, the most reliable driver development toolkit serving leading companies for more than 20 years, offers DMA, kernel plugins, and handlers API. Not just that, WinDriver comes with a sample folder, including tested interrupt handlers, DMA, and kernel plugin, and code samples for DMA IPs by AMD/Xilinx, Intel/Altera, and Lattice among others. Regarding coding, WinDriver offers no-code features, including generating code for I/O operations and predefined actions set in the DriverWizard. 

Want to learn more about WinDriver? Contact our team today.
Download WinDriver for free, and enjoy our 30-day trial.

Effective Management of Device-Drivers Development Team

Bringing a device to life is no walk in the park. It’s the culmination of a rigorous journey through intricate challenges, and even then, the work doesn’t stop there. Throughout its lifespan, a device needs constant attention and evolution.

Somehow the physical material, electric circuits, chips, and firmware should perform specific tasks deterministically on a well-established operating system. It’s not only about the team’s expertise but also about the synergy of their collaborative efforts. 

Here are a few points to take into account when building and planning an effective device-drivers development team:

Common Language – Computers have compilers/interpreters to break down meanings. We humans, however, have a much wider context. Functions, logs, and calls coherency are key and can be achieved only with elaborate communication via recorded meetings, reviews, or (good) written documentation. Moreover, in large companies and growing teams, effective documentation can save valuable onboarding and hand-off time. 

Coherent Architecture – With sophistication comes complexity. Rooting for a coherent architecture is easier said than done. However, it shouldn’t stop us from striving to and pointing out the importance of it. An easy-to-grasp system takes less effort to get everyone on the same page when starting from scratch. In case of continuous development, or across different teams, the knowledge transfer can be quicker. 

Multi-Scale Compatibility – the product development and distribution process should be aligned with ever-changing environments; IDEs, kernels and operating systems, debugging tools, and other dependencies. Both people and toolkits should allow cross-platform scalability, during the whole product lifetime. Platforms and version adaptability will ensure your product’s relevancy for the latest platforms, and more importantly (security-wise), the ones that are still supported. 

WinDriver, the driver development toolkit by Jungo, offers a range of tools to bridge development gaps, ideal for an effective device-drivers development team. It comes with a built-in API, allowing developers to perform kernel operations from the user-mode, which simplifies the code, the debugging, and the hand-off. WinDriver supports all PCIe/USB devices and is cross-platform compatible for Windows/Linux/Linux ARM/MacOS, both for development and distribution. Every function and feature is widely documented, alongside its growing content center.

Download WinDriver for free, and enjoy our 30-day trial.
Learn more about WinDriver, contact our team today.

Download WinDriver Free 30 Days Trial

Please fill the form below to download a fully featured WinDriver evaluation

Software License Agreement of WinDriver (TM) Version v16.4.0
© Jungo Connectivity Ltd. 2024 All Rights Reserved

IMPORTANT – READ CAREFULLY: THIS SOFTWARE LICENSE AGREEMENT (“AGREEMENT”) IS A LEGAL AGREEMENT BETWEEN YOU AND JUNGO CONNECTIVITY LTD. (“JUNGO”), FOR THE WINDRIVER SOFTWARE PRODUCT ACCOMPANYING THIS LICENSE (THE “SOFTWARE”). BY INSTALLING, COPYING OR OTHERWISE USING THE SOFTWARE, YOU AGREE TO BE LEGALLY BOUND BY THE TERMS AND CONDITIONS OF THIS AGREEMENT. IF YOU DO NOT AGREE TO THE TERMS AND CONDITIONS OF THIS AGREEMENT, DO NOT INSTALL, COPY, OR OTHERWISE USE THE SOFTWARE.

 

  1. OWNERSHIP OF THE SOFTWARE. All right, title, and interest in and to the Software, including associated intellectual property rights, of any sort and/or kind, are and shall remain solely with Jungo and its licensors, and may be protected by copyright, trademark, patent and trade secret law and international treaties. This Agreement does not convey to you an interest in or to the Software, but only a limited, non-transferable, non-sublicensable, non-exclusive, and revocable right of use, in accordance with the terms of this Agreement. You may not remove any proprietary notices and/or any legends from the Software, in whole or in part.

 

  1. GRANT OF LICENSE. Jungo hereby grants you a personal, non-exclusive, nontransferable, non-sublicensable node-locked and time limited license to use the Software.

 

    – Individuals: Jungo grants you, as an individual, a personal, non-exclusive, “single-user” license to use the Software on a single computer, in the manner provided below, at the site for which the license was given.

 

    – Entities: If you are an entity, Jungo grants you the right to designate one individual within your organization (and only one) to have the right to use the Software on a single computer, in the manner provided below, at the site for which the license was given.

 

    – License Scope: A single user license allows usage of WinDriver and redistribution of certain components (as defined below) within a single end product SKU, for a single device (identified by its VID/PID (USB) or VID/DID (PCI)), and without SDK/API capabilities.  If you need extended license or distribution rights, please contact Jungo.

 

  1. EVALUATION LICENSE. If you have not yet paid license fees for the use of the Software, then Jungo hereby grants you a personal, non-exclusive, non-transferable and non-sublicensable license to internally use the Software for evaluation purposes only, for a period of 30 days (the “Evaluation License”). If, after the expiration of the Evaluation License, you wish to continue using the Software and accompanying written materials, you may do so by remitting the required payment to Jungo, and you will then receive a registration code and a license string that will permit you to use the Software on a single computer under one of the license schemes specified in Section 2 above.

 

  1. SERVICE OPTIMIZATION AND ENHANCEMENT. To continuously improve and optimize Jungo’s services, Jungo reserves the right to anonymously monitor, collect, and analyze usage data, including but not limited to API interactions, performance metrics, and system activity. Such data collection and analysis shall be conducted in compliance with all applicable laws and regulations and shall be used solely for the purpose of enhancing service performance, security, and reliability.
  2. SUBSCRIPTION, SERVICE CONTINUITY, RENEWAL, AND LATE PAYMENT PENALTIES. Access to the WinDriver and its associated features is provided on a subscription basis, subject to annual renewal. Failure to renew the subscription before the expiration date may result in the automatic termination of access to the platform and all related services, and additional fees (including but not limited to late payment penalties, administrative charges, or reinstatement costs). Upon termination, the user shall forfeit any rights to continued use, and we reserve the right to suspend or delete any associated accounts, data, or functionalities without further notice.

 

  1. OPEN SOURCE. The Software includes certain files that are subject to open source licenses. These files are identified in their header files (“Open Source Files”). You must use the Open Source Files in accordance with the terms of their respective licenses.  In the event of any contradiction between the terms of this Agreement, and the terms of the open source license accompanying a certain Open Source File, the terms of the latter shall prevail, with regard to the said Open Source File.

 

RESTRICTIONS ON USE AND TRANSFER

 

  1. DISTRIBUTION OF FILES.

 

    (a) You may not distribute, or otherwise transfer or assign, any portion of the Software, including any of the headers or source files that are included in the Software, unless otherwise expressly permitted in this Agreement, subject to the provisions of Section 4 above.

 

    (b) Subject to your full and continued compliance with the terms of this Agreement, including the ongoing payment of annual license fees, you may distribute the following files:

 

Windows:
-windrvr1640.sys
-windrvr1640_legacy.sys
-windrvr1640.inf
-windrvr1640.cat
-wdapi1640.dll
-wdapi1640_32.dll
-wdapi1640_arm64.dll
-wdapi_dotnet1640.dll
-wdapi_dotnet1640_32.dll
-wdapi_netcore1640.dll
-wdapi_java1640.dll
-wdapi_java1640.jar
-wdreg.exe
-difxapi.dll
-devcon.exe
-windrvr1630.sys
-windrvr1630.inf
-wd1630.cat
-wdapi1630.dll
-wdapi_dotnet1630.dll
-wdapi_java1630.dll wdapi_java1600.jar
-windrvr1220.dll
-wdapi1220.dll

Linux:
-windrvr_gcc_v3.o_shipped
-windrvr_gcc_v3_regparm.o_shipped
-kp_linux_gcc_v3.o
-kp_linux_gcc_v3_regparm.o
-libwdapi1640.so libwdapi1640_32.so
-libwdapi_java1640.so
-libwdapi_java1640_32.so
-wdapi_java1640.jar
-wdapi_netcore1640.dll
-kp_wdapi1640_gcc_v3.o_shipped
-kp_wdapi1640_gcc_v3_regparm.o_shipped
-linux_wrappers.c
-linux_wrappers.h
-wdusb_linux.c
-wdusb_interface.h
-wd_ver.h
-linux_common.h
-windrvr.h
-windrvr_usb.h
-wdsriov_interface.h
-wdsriov_linux.c
-wdreg
-configure makefile.in
-configure.wd makefile.wd.in
-makefile.wd.kbuild.in
-configure.usb
-makefile.usb.in
-makefile.usb.kbuild.in
-setup_inst_dir
-windrvr_gcc_v2.a windrvr_gcc_v3.a windrvr_gcc_v3_regparm.a
-kp_linux_gcc_v2.o kp_linux_gcc_v3.o kp_linux_gcc_v3_regparm.o
-libwdapi1630.so
-libwdapi_java1630.so wdapi_java1600.java
-kp_wdapi1630_gcc_v2.a kp_wdapi1600_gcc_v3.a kp_wdapi1600_gcc_v3_regparm.a
-linux_wrappers.c linux_wrappers.h wdusb_linux.c
-wdusb_interface.h wd_ver.h linux_common.h windrvr.h windrvr_usb.h
-configure.wd makefile.wd.in makefile.wd.kbuild.in
-configure.usb makefile.usb.in makefile.usb.kbuild.in

macOS:
-libwdapi1640.dyld
-libwdapi_java1640.jar
-libwdapi_java1640.dyld
-wdapi_netcore1640.dll
-WinDriver1640.kext
-WinDriver1640.dext
-wd_mac_install.sh
-wd_mac_uninstall.sh

 

    (c) The files listed in Section 5.b above may be distributed only as part of a complete application that you distribute under your organization name, and only if they significantly contribute to the functionality of your application. For avoidance of doubt, each organization distributing these files as part of the organization products is required to have valid license(s) under the organization name/VID, irrespective of the party who actually performed the product development. Licenses granted to subcontractors do not grant distribution or other rights to the organizations for which they are developing.

 

    (d) The distribution of the windrvr.h header file is permitted only on Linux.

 

    (e) You may not modify the distributed files specified in Section 5.b of this Agreement.

 

    (f) You may not distribute any header file that describes the WinDriver functions, or functions that call the WinDriver functions and have the same basic functionality as that of the WinDriver functions.

 

  1. The Software may not be used to develop a development product, an API, or any products, which will eventually be part of a development product or environment, without the written consent of Jungo and subject to additional fees and licensing terms.

 

  1. You may make printed copies of the written materials accompanying the Software, provided that only users bound by this license use them.

 

  1. You may not allow any third party to use the Software, grant access to the Software (or any portion thereof) to any third party, or otherwise make any commercial use of the Software, including without limitation, assign, distribute, sublicense, transfer, pledge, lease, rent, or share your rights in the Software or any of your rights under this Agreement, all whether or not for any consideration.

 

  1. You may not translate, reverse engineer, decompile, disassemble, reproduce, duplicate, copy, or otherwise disseminate all or any part of the Software, or extract source code from the object code of the Software.

 

  1. Jungo reserves the right to revise, update, change, modify, add to, supplement, or delete any and all terms of this License Agreement; provided, however, that changes to this License Agreement will not be applied retroactively. Such changes will be effective with or without prior notice to you. You can review the most current version of this License Agreement under the WinDriver download form page.

 

  1. You may not incorporate or link any open source software with any open source software part of the Software, or otherwise take any action which may cause the Software or any portion thereof to be subjected to the terms of the Free Software Foundation’s General Public License (GPL) or Lesser General Public License (LGPL), or of any other open source code license.

 

  1. DISCLAIMER OF WARRANTY. THIS SOFTWARE AND ITS ACCOMPANYING WRITTEN MATERIALS ARE PROVIDED BY JUNGO “AS IS” WITHOUT ANY WARRANTY. ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT, ARE HEREBY DISCLAIMED TO THE FULLEST EXTENT PERMITTED UNDER APPLICABLE LAW.

 

  1. NO LIABILITY. TO THE FULLEST EXTENT PERMITTED BY APPLICABLE LAW, IN NO EVENT SHALL JUNGO OR ITS LICENSORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, SAVINGS, IP INFRINGEMENT OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

 

  1. Governing Law. This Agreement and use of the Software are governed by the laws of the State of Israel, regardless of its conflict of laws rules, and the competent courts of the State of Israel shall have sole and exclusive jurisdiction over any dispute under this Agreement or otherwise related to the Software.

 

  1. Confidentiality. The Software, including any additional information related thereto, contains confidential and proprietary information of Jungo.  Accordingly, you agree that you will not, nor allow any third party to, disseminate, transfer, grant access to, or otherwise disclose to any third party the Software or any part thereof or any other confidential or proprietary information of Jungo provided in connection therewith. You will maintain all copies of the Software and all related documentation in confidence.

 

  1. Termination and Effects of Termination. Jungo may terminate this Agreement and the licenses granted to you hereunder at any time if you breach any of your obligations hereunder, by issuance of written notice to such effect, addressed to you at the address you provided in your registration form. Upon expiration or other termination of this Agreement, the Licenses granted to you hereunder shall immediately and automatically be canceled, and you will immediately remove all copies of the Software from your computer(s) and cease any use thereof.

 

  1. Contact Details. If you have any questions concerning this Agreement or wish to contact Jungo for any reason —

 

          Web site: https://www.jungo.com

          Email:    [email protected]

 

  1. US GOVERNMENT RESTRICTED RIGHTS. The Software and documentation are provided with RESTRICTED RIGHTS.

  Use, duplication, or disclosure by the Government is subject to restrictions set forth in subparagraph (c)(1) of The Rights in Technical Data and Computer Software clause at DFARS 252.227-7013 or subparagraphs (c)(1)(ii) and (2) of Commercial Computer Software – Restricted Rights at 48 CFR 52.227-19, as applicable.

 

  1. Automatic Renewal. The subscription shall be automatically renewed, unless Licensee notifies Licensor 30 days or more prior to the expiration date of the subscription, of its intent not to renew the subscription.

Accessibility Toolbar