Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

The holy grail of PRs #1

Open
wants to merge 18 commits into
base: main
Choose a base branch
from
Open

The holy grail of PRs #1

wants to merge 18 commits into from

Conversation

erman-dev
Copy link
Owner

No description provided.

when:
- kernel_module.force_build | default(False) or module_type == "missing"
- name: Build and load the module
when: insert_kernel_module_data | check_cpu_constraints | bool
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The logic should be:

  • no kernel module is inserted if the cpu constraints are not met.
  • thus, this check (check_cpu_constraints) should be done right after checking role parameters and if false, don't do any action inside this role.

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for the feedback. Should be addressed in 33036e3.



def get_cpu_info():
info = cpuinfo.get_cpu_info()
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

2 points:

  • ansible filters are for data manipulation. They are not intended to execute any actions / data collection on hosts
  • code of filters are executed centrally on ansible controller, not on target hosts. Hence this will not work

cpu information will be needed to collecto on role level, like:
handle_module: "{{ cpu_constraints | check_cpu_constraints(cpu_family, cpu_model) }}"

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for the feedback. Should be addressed in 33036e3

raise ValueError(
"Constraints needs to be int or list of ranges!"
)
if is_in_range(value, range.get("start", 0), range.get("end", 255)):
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we need to cap the range to 255? It looks like unnecessary conctraint to me.

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If i understood correctly, the model number is one byte (0x00 to 0xFF) - thus the range should be from 0 to 255.

But I can make additional logic that would be used in case the range is open either from left or right side, so we don't need to cap the range.

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Addressed in ff0daa1 . The limits of 0 and 255 were replaced by -inf and inf

Copy link
Collaborator

@martin-mat martin-mat left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

regarding insert_kernel_module: few nitpicking comments. Other than that is is ok.

# Sometimes it might be preffered to use the off-tree module instead of the module
# that is already shipped with the kernel. When a force_build flag is set for
# a module a build_module.yml will be called instead of loading it.
# NOTE(r-krcek): This needs testing, I am not sure if it works as-is!!
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

to be tested and this line to be removed then

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Tested by Roman, needs testing by third party


- fail:
- name: "Fail on incorrect input : {{ insert_kernel_module_data.name }}"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What happens when insert_kernel_module_data.name is not defined here? This is what is being checked in this task, right? Won't it fail earlier on the task name then?

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It would not work, it would fail before displaying the correct text. Fixed in bb75c55

# Detect what type of kernel module it is - builtin, loadable, or missing
- import_tasks: detect_module.yml
- name: "Import CPU info tasks"
ansible.builtin.import_tasks: cpu_info.yml
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm wondering whether it is worth it to separate this into an included file. Drawbacks: one need to take a look to a different file just for few tasks, and it's not clear from where insert_kernel_module_cpu_family and insert_kernel_module_cpu_model come from.

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The tasks were moved to main in 9202f63

@@ -0,0 +1,81 @@
#!/usr/bin/python3
Copy link
Collaborator

@martin-mat martin-mat Dec 9, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

filename: insert_kernel_modules.py is misleading. Better cpu_constraints.py?

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Renamed in e522a51

@@ -1,50 +1,45 @@
---
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can we do it in more generic way?

  • deliver list of needed boot options as an input to the role (configured in group_vars/all.yml)
  • the role will assure that the options are inserted

success_msg: "BIOS CPPC setting is correct."
- name: Add or modify amd_pstate parameter in GRUB
ansible.builtin.lineinfile:
path: /etc/default/grub
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we need to make sure that it is valid path for all supported linux distributions.
Also, set this path as a constant in role's vars. It is used multiple times in main.yml

- cpuinfo_cppc_output.stdout | length > 0
fail_msg: "BIOS CPPC setting is not correct. Enable CPPC in BIOS."
success_msg: "BIOS CPPC setting is correct."
- name: Add or modify amd_pstate parameter in GRUB
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Before doing this, make sure that the GRUB_CMDLINE_LINUX_DEFAULT is there.

ansible.builtin.lineinfile:
path: /etc/default/grub
regexp: '^{{ grub_cmdline }}='
line: '{{ grub_cmdline }}="amd_pstate=passive"'
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • we need to keep options that was there before
  • think also about edge conditions (file does not exist -> create? GRUB_CMDLINE_LINUX_DEFAULT not present -> add it?

fail_msg: "BIOS Monitor and Mwait setting is not correct. Enable Monitor and Mwait in BIOS."
success_msg: "BIOS Monitor and Mwait setting is correct."
- name: Fail if reboot is required
ansible.builtin.fail:
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fail is not correct in this case. I'd suggest:

  • issue a warning instructing the user to do reboot after playbook finish
  • provide an option to proceed with the node reboot as a part of this role at the end (flag in /group_vars.all.yml)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants