The Linux Commit Analyzer tracks patches from upstream and downstream kernels.
Перейти к файлу
microsoft-github-policy-service[bot] 37bc7c91ed
Microsoft mandatory file
2022-08-02 16:07:24 +00:00
DatabaseDriver remove github repo secrets requirement (#9) 2022-03-15 09:49:26 -07:00
DownstreamTracker Undo `--bare` cloning of linux.git 2020-08-29 06:35:09 -07:00
Objects Add license files and headers 2020-06-22 16:54:56 -07:00
Repos Downstream logic working for Ubuntu, SUSE. Debian currently broken. 2020-02-13 15:28:56 -08:00
UpstreamTracker Undo `--bare` cloning of linux.git 2020-08-29 06:35:09 -07:00
Util Add additional ubuntu releases to tracking (#8) 2022-02-09 16:44:44 -08:00
.flake8 Ignore line-limit warnings 2020-03-26 18:44:27 -07:00
.gitignore Import and analyze spreadsheet of commits 2020-07-17 17:46:15 -07:00
.isort.cfg Configure isort 2020-03-26 18:43:05 -07:00
CODE_OF_CONDUCT.md Add Code of Conduct and legal notices 2020-06-23 12:44:56 -07:00
CommA.py Refactor distro export into commit update sequence 2020-07-24 13:36:57 -07:00
LICENSE-DOCS.md Add license files and headers 2020-06-22 16:54:56 -07:00
LICENSE.md Add license files and headers 2020-06-22 16:54:56 -07:00
README.md remove github repo secrets requirement (#9) 2022-03-15 09:49:26 -07:00
SECURITY.md Microsoft mandatory file 2022-08-02 16:07:24 +00:00
__init__.py Add license files and headers 2020-06-22 16:54:56 -07:00
azure-pipelines.yml Remove production scheduled update from pipeline 2020-06-25 14:05:44 -07:00
poetry.lock Add pyls-isort dev package 2020-07-25 22:21:57 -07:00
pyproject.toml Add pyls-isort dev package 2020-07-25 22:21:57 -07:00

README.md

Linux Commit Analyzer (CommA)

Build Status

This tool populates a database with the details of which patches that are upstream (in linux-mainline) are missing from distros in their downstream kernels (e.g. Ubuntu kernels). For our use case, we are looking at Hyper-V patches and checking downstream azure specific kernels, but this is adaptable.

Getting Started

Install Dependencies

Install python3 via apt and then it as default:

This is not technically required but is a recommended configuration, as poetry expects some Python at python. You could also install Python 2.7.

apt install python3 python3-pip python3-venv
update-alternatives --install /usr/bin/python python /usr/bin/python3 1
update-alternatives --install /usr/bin/pip pip /usr/bin/pip3 1

Install poetry:

Caution: this modifies your .bashrc.

curl -sSL https://raw.githubusercontent.com/python-poetry/poetry/master/get-poetry.py | python

Setup Microsoft SQL repos (this is for mssql-tools):

Caution: these commands use sudo and add a package repository. Change the Ubuntu version to your version (cat /etc/os-release for the number).

. /etc/os-release
curl https://packages.microsoft.com/keys/microsoft.asc | sudo apt-key add -
curl https://packages.microsoft.com/config/ubuntu/${VERSION_ID}/prod.list | sudo tee /etc/apt/sources.list.d/msprod.list

Install the required packages for connecting to the Microsoft SQL database:

apt update
apt install mssql-tools unixodbc-dev

Install Python packages via poetry:

poetry install

For the symbol matcher, install exuberant-ctags as the default ctags will not work:

apt install exuberant-ctags

Running CommA

  1. Enter the setup environment with poetry shell
  2. Provide the URL to the secrets repo with export COMMA_SECRETS_URL=<URL/to/secrets/repo>.
  3. Run ./CommA.py run --upstream --downstream

This will parse the upstream and downstream repos.

Setting Up Secrets

Place database info into the following environment variables before running CommA: COMMA_DB_URL COMMA_DB_NAME COMMA_DB_USERNAME COMMA_DB_PW

[!TIP] We leave it to the user to keep their secrets secure before running CommA. Azure Pipelines provides a few mechanisms for managing secrets, use a comparable tool when creating a CommA pipeline to ensure you don't leak your database credentials.

Contributing

This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.

When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

Microsoft and any contributors grant you a license to the Microsoft documentation and other content in this repository under the Creative Commons Attribution 4.0 International Public License, see the LICENSE-DOCS file, and grant you a license to any code in the repository under the MIT License, see the LICENSE file.

Microsoft, Windows, Microsoft Azure and/or other Microsoft products and services referenced in the documentation may be either trademarks or registered trademarks of Microsoft in the United States and/or other countries. The licenses for this project do not grant you rights to use any Microsoft names, logos, or trademarks. Microsoft's general trademark guidelines can be found at http://go.microsoft.com/fwlink/?LinkID=254653.

Privacy information can be found at https://privacy.microsoft.com/en-us/

Microsoft and any contributors reserve all other rights, whether under their respective copyrights, patents, or trademarks, whether by implication, estoppel or otherwise.