From cd07449a4865a5975a5f6e0e6e3dc23adb5334e2 Mon Sep 17 00:00:00 2001 From: Edith Boles Date: Wed, 8 Apr 2026 22:14:59 -0700 Subject: [PATCH] Add hw1 --- hw1/sample_string_reverse | Bin 0 -> 18784 bytes hw1/sample_string_reverse.c | 28 ++ hw1/section_a.md | 59 +++ hw1/section_b.txt | 26 ++ hw1/section_c.txt | 12 + hw1/section_d/.clang-format | 806 ++++++++++++++++++++++++++++++++++++ hw1/section_d/.clangd | 0 hw1/section_d/Makefile | 12 + hw1/section_d/dmesg.txt | 6 + hw1/section_d/hello.c | 17 + 10 files changed, 966 insertions(+) create mode 100755 hw1/sample_string_reverse create mode 100644 hw1/sample_string_reverse.c create mode 100644 hw1/section_a.md create mode 100644 hw1/section_b.txt create mode 100644 hw1/section_c.txt create mode 100644 hw1/section_d/.clang-format create mode 100644 hw1/section_d/.clangd create mode 100644 hw1/section_d/Makefile create mode 100644 hw1/section_d/dmesg.txt create mode 100644 hw1/section_d/hello.c diff --git a/hw1/sample_string_reverse b/hw1/sample_string_reverse new file mode 100755 index 0000000000000000000000000000000000000000..a1bdf3f1ecb01fc392f29f1a7d0f7158dc7e0fad GIT binary patch literal 18784 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 hgE^YvFnb}YKz%_(-hqjM=R20RVE=I-39h literal 0 HcmV?d00001 diff --git a/hw1/sample_string_reverse.c b/hw1/sample_string_reverse.c new file mode 100644 index 0000000..0eb53d3 --- /dev/null +++ b/hw1/sample_string_reverse.c @@ -0,0 +1,28 @@ + +#include +int main(int argc, char *argv[]) +{ + char buf[50]; + + printf("Input string to reverse: "); + fgets(buf, 50, stdin); + + int max = 0; + char *c = buf; + while (*c++) + max++; + max--; + buf[max] = '\0'; + max--; + + for (int i = 0; i < max - i; i++) { + int top = max - i; + char temp = buf[top]; + buf[top] = buf[i]; + buf[i] = temp; + } + + printf("Reversed: %s\n", buf); + + return 0; +} diff --git a/hw1/section_a.md b/hw1/section_a.md new file mode 100644 index 0000000..ba218e5 --- /dev/null +++ b/hw1/section_a.md @@ -0,0 +1,59 @@ +--- +title: ECE 371 HW 1 +author: Edith Boles +--- + +1. `open()` system call + + A. List the BUGS when using the system call. + + > BUGS + > + > Currently, it is not possible to enable signal-driven I/O by specifying O_ASYNC when calling open(); use fcntl(2) to enable this flag. + > + > One must check for two different error codes, EISDIR and ENOENT, when trying to determine whether the kernel supports O_TMPFILE functionality. + > + > When both O_CREAT and O_DIRECTORY are specified in flags and the file specified by pathname does not exist, open() will create a regular file (i.e., O_DIRECTORY is ignored). + + B. What files need to be included to use this function? + + `open` is inside `fcntl.h`. + + C. List the first three related system calls to open(). + + ``` + SEE ALSO + chmod(2), chown(2), close(2), ... + ``` + + D. Choose one of the system calls from above and list its bugs (also list + what system call you chose) and files needing to be included to use + the system call + + For `link(2)`, you need to include `fcntrl.h` and `unistd.h`. The `BUGS` section details an issue on NFS filesystems that requires verifying the operation before assuming it succeeded. + +2. https://elixir.bootlin.com/, searching on kernel `v6.19.11` + + A. `usb_device` is defined in `include/linux/usb.h`, with first five members being: + + ``` + int devnum; + char devpath[16]; + u32 route; + enum usb_device_state state; + enum usb_device_speed speed; + ``` + + B. `include/uapi/linux/usb/ch9.h` + + C. ``` + enum usb_device_speed { + USB_SPEED_UNKNOWN = 0, /* enumerating */ + USB_SPEED_LOW, USB_SPEED_FULL, /* usb 1.1 */ + USB_SPEED_HIGH, /* usb 2.0 */ + USB_SPEED_WIRELESS, /* wireless (usb 2.5) */ + USB_SPEED_SUPER, /* usb 3.0 */ + USB_SPEED_SUPER_PLUS, /* usb 3.1 */ + }; + ``` + diff --git a/hw1/section_b.txt b/hw1/section_b.txt new file mode 100644 index 0000000..147b2a7 --- /dev/null +++ b/hw1/section_b.txt @@ -0,0 +1,26 @@ +Script started on 2026-04-07 23:38:25+00:00 [TERM="xterm-256color" TTY="/dev/pts/0" COLUMNS="77" LINES="35"] +To run a command as administrator (user "root"), use "sudo ". +See "man sudo_root" for details. + +edith@ece-373-vm:~$ pwd +/home/edith +edith@ece-373-vm:~$ ls -la +total 48 +drwxr-x--- 5 edith edith 4096 Apr 7 23:38 . +drwxr-xr-x 3 root root 4096 Apr 7 22:22 .. +-rw-r--r-- 1 edith edith 220 Mar 31 2024 .bash_logout +-rw-r--r-- 1 edith edith 3771 Mar 31 2024 .bashrc +drwx------ 2 edith edith 4096 Apr 7 22:22 .cache +-rw------- 1 edith edith 118 Apr 7 23:38 .lesshst +-rw-r--r-- 1 edith edith 807 Mar 31 2024 .profile +drwx------ 2 edith edith 4096 Apr 7 22:22 .ssh +-rw-rw-r-- 1 edith edith 0 Apr 7 23:38 typescript +drwxrwxr-x 6 edith edith 4096 Apr 7 22:24 .vim +-rw------- 1 edith edith 556 Apr 7 22:24 .viminfo +-rw-r--r-- 1 edith edith 7747 Apr 7 22:24 .vimrc +edith@ece-373-vm:~$ mkdir ece373 +edith@ece-373-vm:~$ cd ece373/ +edith@ece-373-vm:~/ece373$ +exit + +Script done on 2026-04-07 23:39:16+00:00 [COMMAND_EXIT_CODE="0"] diff --git a/hw1/section_c.txt b/hw1/section_c.txt new file mode 100644 index 0000000..7f2bba1 --- /dev/null +++ b/hw1/section_c.txt @@ -0,0 +1,12 @@ +Script started on 2026-04-08 23:27:01-07:00 [TERM="xterm-256color" TTY="/dev/pts/1" COLUMNS="77" LINES="35"] +]0;edith@edith-long:~/devel/ece373/hw1[?2004h[edith@edith-long hw1]$ gcc -g -o sample_string_reverse sample_string_reverse.c [edith@edith-long hw1]$ gcc -g -o sample_string_reverse sample_string_reverse.c +[?2004l ]0;edith@edith-long:~/devel/ece373/hw1[?2004h[edith@edith-long hw1]$ ./sample_string_reverse +[?2004l Input string to reverse: chicken +Reversed: nekcihc +]0;edith@edith-long:~/devel/ece373/hw1[?2004h[edith@edith-long hw1]$ ./sample_string_reverse +[?2004l Input string to reverse: 1234567890 +Reversed: 0987654321 +]0;edith@edith-long:~/devel/ece373/hw1[?2004h[edith@edith-long hw1]$ exit +[?2004l exit + +Script done on 2026-04-08 23:27:45-07:00 [COMMAND_EXIT_CODE="0"] diff --git a/hw1/section_d/.clang-format b/hw1/section_d/.clang-format new file mode 100644 index 0000000..1cc151e --- /dev/null +++ b/hw1/section_d/.clang-format @@ -0,0 +1,806 @@ +# SPDX-License-Identifier: GPL-2.0 +# +# clang-format configuration file. Intended for clang-format >= 11. +# +# For more information, see: +# +# Documentation/dev-tools/clang-format.rst +# https://clang.llvm.org/docs/ClangFormat.html +# https://clang.llvm.org/docs/ClangFormatStyleOptions.html +# +--- +AccessModifierOffset: -4 +AlignAfterOpenBracket: Align +AlignConsecutiveAssignments: false +AlignConsecutiveDeclarations: false +AlignEscapedNewlines: Left +AlignOperands: true +AlignTrailingComments: false +AllowAllParametersOfDeclarationOnNextLine: false +AllowShortBlocksOnASingleLine: false +AllowShortCaseLabelsOnASingleLine: false +AllowShortFunctionsOnASingleLine: None +AllowShortIfStatementsOnASingleLine: false +AllowShortLoopsOnASingleLine: false +AlwaysBreakAfterDefinitionReturnType: None +AlwaysBreakAfterReturnType: None +AlwaysBreakBeforeMultilineStrings: false +AlwaysBreakTemplateDeclarations: false +BinPackArguments: true +BinPackParameters: true +BraceWrapping: + AfterClass: false + AfterControlStatement: false + AfterEnum: false + AfterFunction: true + AfterNamespace: true + AfterObjCDeclaration: false + AfterStruct: false + AfterUnion: false + AfterExternBlock: false + BeforeCatch: false + BeforeElse: false + IndentBraces: false + SplitEmptyFunction: true + SplitEmptyRecord: true + SplitEmptyNamespace: true +BreakBeforeBinaryOperators: None +BreakBeforeBraces: Custom +BreakBeforeInheritanceComma: false +BreakBeforeTernaryOperators: false +BreakConstructorInitializersBeforeComma: false +BreakConstructorInitializers: BeforeComma +BreakAfterJavaFieldAnnotations: false +BreakStringLiterals: false +ColumnLimit: 80 +CommentPragmas: '^ IWYU pragma:' +CompactNamespaces: false +ConstructorInitializerAllOnOneLineOrOnePerLine: false +ConstructorInitializerIndentWidth: 8 +ContinuationIndentWidth: 8 +Cpp11BracedListStyle: false +DerivePointerAlignment: false +DisableFormat: false +ExperimentalAutoDetectBinPacking: false +FixNamespaceComments: false + +# Taken from: +# git grep -h '^#define [^[:space:]]*for_each[^[:space:]]*(' include/ tools/ \ +# | sed "s,^#define \([^[:space:]]*for_each[^[:space:]]*\)(.*$, - '\1'," \ +# | LC_ALL=C sort -u +ForEachMacros: + - '__ata_qc_for_each' + - '__bio_for_each_bvec' + - '__bio_for_each_segment' + - '__evlist__for_each_entry' + - '__evlist__for_each_entry_continue' + - '__evlist__for_each_entry_from' + - '__evlist__for_each_entry_reverse' + - '__evlist__for_each_entry_safe' + - '__for_each_mem_range' + - '__for_each_mem_range_rev' + - '__for_each_thread' + - '__hlist_for_each_rcu' + - '__map__for_each_symbol_by_name' + - '__pci_bus_for_each_res0' + - '__pci_bus_for_each_res1' + - '__pci_dev_for_each_res0' + - '__pci_dev_for_each_res1' + - '__perf_evlist__for_each_entry' + - '__perf_evlist__for_each_entry_reverse' + - '__perf_evlist__for_each_entry_safe' + - '__rq_for_each_bio' + - '__shost_for_each_device' + - '__sym_for_each' + - '_for_each_counter' + - 'apei_estatus_for_each_section' + - 'ata_for_each_dev' + - 'ata_for_each_link' + - 'ata_qc_for_each' + - 'ata_qc_for_each_raw' + - 'ata_qc_for_each_with_internal' + - 'ax25_for_each' + - 'ax25_uid_for_each' + - 'bio_for_each_bvec' + - 'bio_for_each_bvec_all' + - 'bio_for_each_folio_all' + - 'bio_for_each_integrity_vec' + - 'bio_for_each_segment' + - 'bio_for_each_segment_all' + - 'bio_list_for_each' + - 'bip_for_each_vec' + - 'bond_for_each_slave' + - 'bond_for_each_slave_rcu' + - 'bpf_for_each' + - 'bpf_for_each_reg_in_vstate' + - 'bpf_for_each_reg_in_vstate_mask' + - 'bpf_for_each_spilled_reg' + - 'bpf_object__for_each_map' + - 'bpf_object__for_each_program' + - 'btree_for_each_safe128' + - 'btree_for_each_safe32' + - 'btree_for_each_safe64' + - 'btree_for_each_safel' + - 'card_for_each_dev' + - 'cgroup_taskset_for_each' + - 'cgroup_taskset_for_each_leader' + - 'cpu_aggr_map__for_each_idx' + - 'cpufreq_for_each_efficient_entry_idx' + - 'cpufreq_for_each_entry' + - 'cpufreq_for_each_entry_idx' + - 'cpufreq_for_each_valid_entry' + - 'cpufreq_for_each_valid_entry_idx' + - 'css_for_each_child' + - 'css_for_each_descendant_post' + - 'css_for_each_descendant_pre' + - 'damon_for_each_region' + - 'damon_for_each_region_from' + - 'damon_for_each_region_safe' + - 'damon_for_each_scheme' + - 'damon_for_each_scheme_safe' + - 'damon_for_each_target' + - 'damon_for_each_target_safe' + - 'damos_for_each_core_filter' + - 'damos_for_each_core_filter_safe' + - 'damos_for_each_ops_filter' + - 'damos_for_each_ops_filter_safe' + - 'damos_for_each_quota_goal' + - 'damos_for_each_quota_goal_safe' + - 'data__for_each_file' + - 'data__for_each_file_new' + - 'data__for_each_file_start' + - 'def_for_each_cpu' + - 'device_for_each_child_node' + - 'device_for_each_child_node_scoped' + - 'dma_fence_array_for_each' + - 'dma_fence_chain_for_each' + - 'dma_fence_unwrap_for_each' + - 'dma_resv_for_each_fence' + - 'dma_resv_for_each_fence_unlocked' + - 'do_for_each_ftrace_op' + - 'drm_atomic_crtc_for_each_plane' + - 'drm_atomic_crtc_state_for_each_plane' + - 'drm_atomic_crtc_state_for_each_plane_state' + - 'drm_atomic_for_each_plane_damage' + - 'drm_client_for_each_connector_iter' + - 'drm_client_for_each_modeset' + - 'drm_connector_for_each_possible_encoder' + - 'drm_exec_for_each_locked_object' + - 'drm_exec_for_each_locked_object_reverse' + - 'drm_for_each_bridge_in_chain_scoped' + - 'drm_for_each_connector_iter' + - 'drm_for_each_crtc' + - 'drm_for_each_crtc_reverse' + - 'drm_for_each_encoder' + - 'drm_for_each_encoder_mask' + - 'drm_for_each_fb' + - 'drm_for_each_legacy_plane' + - 'drm_for_each_plane' + - 'drm_for_each_plane_mask' + - 'drm_for_each_privobj' + - 'drm_gem_for_each_gpuvm_bo' + - 'drm_gem_for_each_gpuvm_bo_safe' + - 'drm_gpusvm_for_each_range' + - 'drm_gpuva_for_each_op' + - 'drm_gpuva_for_each_op_from_reverse' + - 'drm_gpuva_for_each_op_reverse' + - 'drm_gpuva_for_each_op_safe' + - 'drm_gpuvm_bo_for_each_va' + - 'drm_gpuvm_bo_for_each_va_safe' + - 'drm_gpuvm_for_each_va' + - 'drm_gpuvm_for_each_va_range' + - 'drm_gpuvm_for_each_va_range_safe' + - 'drm_gpuvm_for_each_va_safe' + - 'drm_mm_for_each_hole' + - 'drm_mm_for_each_node' + - 'drm_mm_for_each_node_in_range' + - 'drm_mm_for_each_node_safe' + - 'dsa_switch_for_each_available_port' + - 'dsa_switch_for_each_cpu_port' + - 'dsa_switch_for_each_cpu_port_continue_reverse' + - 'dsa_switch_for_each_port' + - 'dsa_switch_for_each_port_continue_reverse' + - 'dsa_switch_for_each_port_safe' + - 'dsa_switch_for_each_user_port' + - 'dsa_switch_for_each_user_port_continue_reverse' + - 'dsa_tree_for_each_cpu_port' + - 'dsa_tree_for_each_user_port' + - 'dsa_tree_for_each_user_port_continue_reverse' + - 'dso__for_each_symbol' + - 'elf_hash_for_each_possible' + - 'elf_symtab__for_each_symbol' + - 'evlist__for_each_cpu' + - 'evlist__for_each_entry' + - 'evlist__for_each_entry_continue' + - 'evlist__for_each_entry_from' + - 'evlist__for_each_entry_reverse' + - 'evlist__for_each_entry_safe' + - 'flow_action_for_each' + - 'for_each_acpi_consumer_dev' + - 'for_each_acpi_dev_match' + - 'for_each_active_dev_scope' + - 'for_each_active_drhd_unit' + - 'for_each_active_iommu' + - 'for_each_active_irq' + - 'for_each_active_route' + - 'for_each_aggr_pgid' + - 'for_each_alloc_capable_rdt_resource' + - 'for_each_and_bit' + - 'for_each_andnot_bit' + - 'for_each_available_child_of_node' + - 'for_each_available_child_of_node_scoped' + - 'for_each_bench' + - 'for_each_bio' + - 'for_each_board_func_rsrc' + - 'for_each_btf_ext_rec' + - 'for_each_btf_ext_sec' + - 'for_each_bvec' + - 'for_each_capable_rdt_resource' + - 'for_each_card_auxs' + - 'for_each_card_auxs_safe' + - 'for_each_card_components' + - 'for_each_card_dapms' + - 'for_each_card_pre_auxs' + - 'for_each_card_prelinks' + - 'for_each_card_rtds' + - 'for_each_card_rtds_safe' + - 'for_each_card_widgets' + - 'for_each_card_widgets_safe' + - 'for_each_cgroup_storage_type' + - 'for_each_child_of_node' + - 'for_each_child_of_node_scoped' + - 'for_each_child_of_node_with_prefix' + - 'for_each_clear_bit' + - 'for_each_clear_bit_from' + - 'for_each_clear_bitrange' + - 'for_each_clear_bitrange_from' + - 'for_each_cmd' + - 'for_each_cmsghdr' + - 'for_each_collection' + - 'for_each_comp_order' + - 'for_each_compatible_node' + - 'for_each_compatible_node_scoped' + - 'for_each_component_dais' + - 'for_each_component_dais_safe' + - 'for_each_conduit' + - 'for_each_console' + - 'for_each_console_srcu' + - 'for_each_cpu' + - 'for_each_cpu_and' + - 'for_each_cpu_andnot' + - 'for_each_cpu_from' + - 'for_each_cpu_or' + - 'for_each_cpu_wrap' + - 'for_each_dapm_widgets' + - 'for_each_dedup_cand' + - 'for_each_dev_addr' + - 'for_each_dev_scope' + - 'for_each_dma_cap_mask' + - 'for_each_dpcm_be' + - 'for_each_dpcm_be_rollback' + - 'for_each_dpcm_be_safe' + - 'for_each_dpcm_fe' + - 'for_each_drhd_unit' + - 'for_each_dss_dev' + - 'for_each_efi_memory_desc' + - 'for_each_efi_memory_desc_in_map' + - 'for_each_element' + - 'for_each_element_extid' + - 'for_each_element_id' + - 'for_each_enabled_cpu' + - 'for_each_endpoint_of_node' + - 'for_each_event' + - 'for_each_event_tps' + - 'for_each_evictable_lru' + - 'for_each_fib6_node_rt_rcu' + - 'for_each_fib6_walker_rt' + - 'for_each_file_lock' + - 'for_each_free_mem_range' + - 'for_each_free_mem_range_reverse' + - 'for_each_func_rsrc' + - 'for_each_gpiochip_node' + - 'for_each_group_evsel' + - 'for_each_group_evsel_head' + - 'for_each_group_member' + - 'for_each_group_member_head' + - 'for_each_hstate' + - 'for_each_hwgpio' + - 'for_each_hwgpio_in_range' + - 'for_each_if' + - 'for_each_inject_fn' + - 'for_each_insn' + - 'for_each_insn_op_loc' + - 'for_each_insn_prefix' + - 'for_each_intid' + - 'for_each_iommu' + - 'for_each_ip_tunnel_rcu' + - 'for_each_irq_desc' + - 'for_each_irq_nr' + - 'for_each_lang' + - 'for_each_link_ch_maps' + - 'for_each_link_codecs' + - 'for_each_link_cpus' + - 'for_each_link_platforms' + - 'for_each_lru' + - 'for_each_matching_node' + - 'for_each_matching_node_and_match' + - 'for_each_media_entity_data_link' + - 'for_each_mem_pfn_range' + - 'for_each_mem_range' + - 'for_each_mem_range_rev' + - 'for_each_mem_region' + - 'for_each_member' + - 'for_each_memory' + - 'for_each_migratetype_order' + - 'for_each_missing_reg' + - 'for_each_mle_subelement' + - 'for_each_mod_mem_type' + - 'for_each_mon_capable_rdt_resource' + - 'for_each_mp_bvec' + - 'for_each_net' + - 'for_each_net_continue_reverse' + - 'for_each_net_rcu' + - 'for_each_netdev' + - 'for_each_netdev_continue' + - 'for_each_netdev_continue_rcu' + - 'for_each_netdev_continue_reverse' + - 'for_each_netdev_dump' + - 'for_each_netdev_feature' + - 'for_each_netdev_in_bond_rcu' + - 'for_each_netdev_rcu' + - 'for_each_netdev_reverse' + - 'for_each_netdev_safe' + - 'for_each_new_connector_in_state' + - 'for_each_new_crtc_in_state' + - 'for_each_new_mst_mgr_in_state' + - 'for_each_new_plane_in_state' + - 'for_each_new_plane_in_state_reverse' + - 'for_each_new_private_obj_in_state' + - 'for_each_new_reg' + - 'for_each_nhlt_endpoint' + - 'for_each_nhlt_endpoint_fmtcfg' + - 'for_each_nhlt_fmtcfg' + - 'for_each_node' + - 'for_each_node_by_name' + - 'for_each_node_by_type' + - 'for_each_node_mask' + - 'for_each_node_numadist' + - 'for_each_node_state' + - 'for_each_node_with_cpus' + - 'for_each_node_with_property' + - 'for_each_nonreserved_multicast_dest_pgid' + - 'for_each_numa_hop_mask' + - 'for_each_of_allnodes' + - 'for_each_of_allnodes_from' + - 'for_each_of_cpu_node' + - 'for_each_of_graph_port' + - 'for_each_of_graph_port_endpoint' + - 'for_each_of_pci_range' + - 'for_each_old_connector_in_state' + - 'for_each_old_crtc_in_state' + - 'for_each_old_mst_mgr_in_state' + - 'for_each_old_plane_in_state' + - 'for_each_old_private_obj_in_state' + - 'for_each_oldnew_connector_in_state' + - 'for_each_oldnew_crtc_in_state' + - 'for_each_oldnew_mst_mgr_in_state' + - 'for_each_oldnew_plane_in_state' + - 'for_each_oldnew_plane_in_state_reverse' + - 'for_each_oldnew_private_obj_in_state' + - 'for_each_online_cpu' + - 'for_each_online_cpu_wrap' + - 'for_each_online_node' + - 'for_each_online_pgdat' + - 'for_each_or_bit' + - 'for_each_page_ext' + - 'for_each_path' + - 'for_each_pci_bridge' + - 'for_each_pci_dev' + - 'for_each_pcm_streams' + - 'for_each_physmem_range' + - 'for_each_populated_zone' + - 'for_each_possible_cpu' + - 'for_each_possible_cpu_wrap' + - 'for_each_present_blessed_reg' + - 'for_each_present_cpu' + - 'for_each_present_section_nr' + - 'for_each_prime_number' + - 'for_each_prime_number_from' + - 'for_each_probe_cache_entry' + - 'for_each_process' + - 'for_each_process_thread' + - 'for_each_prop_codec_conf' + - 'for_each_prop_dai_codec' + - 'for_each_prop_dai_cpu' + - 'for_each_prop_dlc_codecs' + - 'for_each_prop_dlc_cpus' + - 'for_each_prop_dlc_platforms' + - 'for_each_property_of_node' + - 'for_each_pt_level_entry' + - 'for_each_rdt_resource' + - 'for_each_reg' + - 'for_each_reg_filtered' + - 'for_each_reloc' + - 'for_each_reloc_from' + - 'for_each_requested_gpio' + - 'for_each_requested_gpio_in_range' + - 'for_each_reserved_child_of_node' + - 'for_each_reserved_mem_range' + - 'for_each_reserved_mem_region' + - 'for_each_rtd_ch_maps' + - 'for_each_rtd_codec_dais' + - 'for_each_rtd_components' + - 'for_each_rtd_cpu_dais' + - 'for_each_rtd_dais' + - 'for_each_rtd_dais_reverse' + - 'for_each_sband_iftype_data' + - 'for_each_script' + - 'for_each_sec' + - 'for_each_set_bit' + - 'for_each_set_bit_from' + - 'for_each_set_bit_wrap' + - 'for_each_set_bitrange' + - 'for_each_set_bitrange_from' + - 'for_each_set_clump8' + - 'for_each_sg' + - 'for_each_sg_dma_page' + - 'for_each_sg_page' + - 'for_each_sgtable_dma_page' + - 'for_each_sgtable_dma_sg' + - 'for_each_sgtable_page' + - 'for_each_sgtable_sg' + - 'for_each_sibling_event' + - 'for_each_sta_active_link' + - 'for_each_subelement' + - 'for_each_subelement_extid' + - 'for_each_subelement_id' + - 'for_each_sublist' + - 'for_each_subsystem' + - 'for_each_suite' + - 'for_each_supported_activate_fn' + - 'for_each_supported_inject_fn' + - 'for_each_sym' + - 'for_each_thread' + - 'for_each_token' + - 'for_each_unicast_dest_pgid' + - 'for_each_valid_link' + - 'for_each_vif_active_link' + - 'for_each_vma' + - 'for_each_vma_range' + - 'for_each_vsi' + - 'for_each_wakeup_source' + - 'for_each_zone' + - 'for_each_zone_zonelist' + - 'for_each_zone_zonelist_nodemask' + - 'func_for_each_insn' + - 'fwnode_for_each_available_child_node' + - 'fwnode_for_each_child_node' + - 'fwnode_for_each_parent_node' + - 'fwnode_graph_for_each_endpoint' + - 'gadget_for_each_ep' + - 'genradix_for_each' + - 'genradix_for_each_from' + - 'genradix_for_each_reverse' + - 'hash_for_each' + - 'hash_for_each_possible' + - 'hash_for_each_possible_rcu' + - 'hash_for_each_possible_rcu_notrace' + - 'hash_for_each_possible_safe' + - 'hash_for_each_rcu' + - 'hash_for_each_safe' + - 'hashmap__for_each_entry' + - 'hashmap__for_each_entry_safe' + - 'hashmap__for_each_key_entry' + - 'hashmap__for_each_key_entry_safe' + - 'hctx_for_each_ctx' + - 'hists__for_each_format' + - 'hists__for_each_sort_list' + - 'hlist_bl_for_each_entry' + - 'hlist_bl_for_each_entry_rcu' + - 'hlist_bl_for_each_entry_safe' + - 'hlist_for_each' + - 'hlist_for_each_entry' + - 'hlist_for_each_entry_continue' + - 'hlist_for_each_entry_continue_rcu' + - 'hlist_for_each_entry_continue_rcu_bh' + - 'hlist_for_each_entry_from' + - 'hlist_for_each_entry_from_rcu' + - 'hlist_for_each_entry_rcu' + - 'hlist_for_each_entry_rcu_bh' + - 'hlist_for_each_entry_rcu_notrace' + - 'hlist_for_each_entry_safe' + - 'hlist_for_each_entry_srcu' + - 'hlist_for_each_safe' + - 'hlist_nulls_for_each_entry' + - 'hlist_nulls_for_each_entry_from' + - 'hlist_nulls_for_each_entry_rcu' + - 'hlist_nulls_for_each_entry_safe' + - 'i3c_bus_for_each_i2cdev' + - 'i3c_bus_for_each_i3cdev' + - 'idr_for_each_entry' + - 'idr_for_each_entry_continue' + - 'idr_for_each_entry_continue_ul' + - 'idr_for_each_entry_ul' + - 'iio_for_each_active_channel' + - 'in_dev_for_each_ifa_rcu' + - 'in_dev_for_each_ifa_rtnl' + - 'in_dev_for_each_ifa_rtnl_net' + - 'inet_bind_bucket_for_each' + - 'interval_tree_for_each_span' + - 'intlist__for_each_entry' + - 'intlist__for_each_entry_safe' + - 'kcore_copy__for_each_phdr' + - 'key_for_each' + - 'key_for_each_safe' + - 'klp_for_each_func' + - 'klp_for_each_func_safe' + - 'klp_for_each_func_static' + - 'klp_for_each_object' + - 'klp_for_each_object_safe' + - 'klp_for_each_object_static' + - 'kunit_suite_for_each_test_case' + - 'kvm_for_each_memslot' + - 'kvm_for_each_memslot_in_gfn_range' + - 'kvm_for_each_vcpu' + - 'libbpf_nla_for_each_attr' + - 'list_for_each' + - 'list_for_each_codec' + - 'list_for_each_codec_safe' + - 'list_for_each_continue' + - 'list_for_each_entry' + - 'list_for_each_entry_continue' + - 'list_for_each_entry_continue_rcu' + - 'list_for_each_entry_continue_reverse' + - 'list_for_each_entry_from' + - 'list_for_each_entry_from_rcu' + - 'list_for_each_entry_from_reverse' + - 'list_for_each_entry_lockless' + - 'list_for_each_entry_rcu' + - 'list_for_each_entry_reverse' + - 'list_for_each_entry_safe' + - 'list_for_each_entry_safe_continue' + - 'list_for_each_entry_safe_from' + - 'list_for_each_entry_safe_reverse' + - 'list_for_each_entry_srcu' + - 'list_for_each_from' + - 'list_for_each_prev' + - 'list_for_each_prev_safe' + - 'list_for_each_rcu' + - 'list_for_each_safe' + - 'llist_for_each' + - 'llist_for_each_entry' + - 'llist_for_each_entry_safe' + - 'llist_for_each_safe' + - 'lwq_for_each_safe' + - 'map__for_each_symbol' + - 'map__for_each_symbol_by_name' + - 'mas_for_each' + - 'mas_for_each_rev' + - 'mci_for_each_dimm' + - 'media_device_for_each_entity' + - 'media_device_for_each_intf' + - 'media_device_for_each_link' + - 'media_device_for_each_pad' + - 'media_entity_for_each_pad' + - 'media_pipeline_for_each_entity' + - 'media_pipeline_for_each_pad' + - 'mlx5_lag_for_each_peer_mdev' + - 'mptcp_for_each_subflow' + - 'msi_domain_for_each_desc' + - 'msi_for_each_desc' + - 'mt_for_each' + - 'nanddev_io_for_each_block' + - 'nanddev_io_for_each_page' + - 'neigh_for_each_in_bucket' + - 'neigh_for_each_in_bucket_rcu' + - 'neigh_for_each_in_bucket_safe' + - 'netdev_for_each_lower_dev' + - 'netdev_for_each_lower_private' + - 'netdev_for_each_lower_private_rcu' + - 'netdev_for_each_mc_addr' + - 'netdev_for_each_synced_mc_addr' + - 'netdev_for_each_synced_uc_addr' + - 'netdev_for_each_uc_addr' + - 'netdev_for_each_upper_dev_rcu' + - 'netdev_hw_addr_list_for_each' + - 'nft_rule_for_each_expr' + - 'nla_for_each_attr' + - 'nla_for_each_attr_type' + - 'nla_for_each_nested' + - 'nla_for_each_nested_type' + - 'nlmsg_for_each_attr' + - 'nlmsg_for_each_msg' + - 'nr_neigh_for_each' + - 'nr_neigh_for_each_safe' + - 'nr_node_for_each' + - 'nr_node_for_each_safe' + - 'of_for_each_phandle' + - 'of_property_for_each_string' + - 'of_property_for_each_u32' + - 'pci_bus_for_each_resource' + - 'pci_dev_for_each_resource' + - 'pcl_for_each_chunk' + - 'pcl_for_each_segment' + - 'pcm_for_each_format' + - 'perf_config_items__for_each_entry' + - 'perf_config_sections__for_each_entry' + - 'perf_config_set__for_each_entry' + - 'perf_cpu_map__for_each_cpu' + - 'perf_cpu_map__for_each_cpu_skip_any' + - 'perf_cpu_map__for_each_idx' + - 'perf_evlist__for_each_entry' + - 'perf_evlist__for_each_entry_reverse' + - 'perf_evlist__for_each_entry_safe' + - 'perf_evlist__for_each_evsel' + - 'perf_evlist__for_each_mmap' + - 'perf_evsel_for_each_per_thread_period_safe' + - 'perf_hpp_list__for_each_format' + - 'perf_hpp_list__for_each_format_safe' + - 'perf_hpp_list__for_each_sort_list' + - 'perf_hpp_list__for_each_sort_list_safe' + - 'plist_for_each' + - 'plist_for_each_continue' + - 'plist_for_each_entry' + - 'plist_for_each_entry_continue' + - 'plist_for_each_entry_safe' + - 'plist_for_each_safe' + - 'pnp_for_each_card' + - 'pnp_for_each_dev' + - 'protocol_for_each_card' + - 'protocol_for_each_dev' + - 'queue_for_each_hw_ctx' + - 'radix_tree_for_each_slot' + - 'radix_tree_for_each_tagged' + - 'rb_for_each' + - 'rbtree_postorder_for_each_entry_safe' + - 'rdma_for_each_block' + - 'rdma_for_each_port' + - 'rdma_umem_for_each_dma_block' + - 'resource_list_for_each_entry' + - 'resource_list_for_each_entry_safe' + - 'rhl_for_each_entry_rcu' + - 'rhl_for_each_rcu' + - 'rht_for_each' + - 'rht_for_each_entry' + - 'rht_for_each_entry_from' + - 'rht_for_each_entry_rcu' + - 'rht_for_each_entry_rcu_from' + - 'rht_for_each_entry_safe' + - 'rht_for_each_from' + - 'rht_for_each_rcu' + - 'rht_for_each_rcu_from' + - 'rq_for_each_bvec' + - 'rq_for_each_segment' + - 'rq_list_for_each' + - 'rq_list_for_each_safe' + - 'sample_read_group__for_each' + - 'scsi_for_each_prot_sg' + - 'scsi_for_each_sg' + - 'sctp_for_each_hentry' + - 'sctp_skb_for_each' + - 'sec_for_each_insn' + - 'sec_for_each_insn_continue' + - 'sec_for_each_insn_from' + - 'sec_for_each_sym' + - 'shdma_for_each_chan' + - 'shost_for_each_device' + - 'sk_for_each' + - 'sk_for_each_bound' + - 'sk_for_each_bound_safe' + - 'sk_for_each_entry_offset_rcu' + - 'sk_for_each_from' + - 'sk_for_each_rcu' + - 'sk_for_each_safe' + - 'sk_nulls_for_each' + - 'sk_nulls_for_each_from' + - 'sk_nulls_for_each_rcu' + - 'snd_array_for_each' + - 'snd_pcm_group_for_each_entry' + - 'snd_soc_dapm_widget_for_each_path' + - 'snd_soc_dapm_widget_for_each_path_safe' + - 'snd_soc_dapm_widget_for_each_sink_path' + - 'snd_soc_dapm_widget_for_each_source_path' + - 'sparsebit_for_each_set_range' + - 'strlist__for_each_entry' + - 'strlist__for_each_entry_safe' + - 'sym_for_each_insn' + - 'sym_for_each_insn_continue_reverse' + - 'symbols__for_each_entry' + - 'tb_property_for_each' + - 'tcf_act_for_each_action' + - 'tcf_exts_for_each_action' + - 'test_suite__for_each_test_case' + - 'tool_pmu__for_each_event' + - 'ttm_bo_lru_for_each_reserved_guarded' + - 'ttm_resource_manager_for_each_res' + - 'udp_lrpa_for_each_entry_rcu' + - 'udp_portaddr_for_each_entry' + - 'udp_portaddr_for_each_entry_rcu' + - 'usb_hub_for_each_child' + - 'v4l2_device_for_each_subdev' + - 'v4l2_m2m_for_each_dst_buf' + - 'v4l2_m2m_for_each_dst_buf_safe' + - 'v4l2_m2m_for_each_src_buf' + - 'v4l2_m2m_for_each_src_buf_safe' + - 'virtio_device_for_each_vq' + - 'vkms_config_for_each_connector' + - 'vkms_config_for_each_crtc' + - 'vkms_config_for_each_encoder' + - 'vkms_config_for_each_plane' + - 'vkms_config_connector_for_each_possible_encoder' + - 'vkms_config_encoder_for_each_possible_crtc' + - 'vkms_config_plane_for_each_possible_crtc' + - 'while_for_each_ftrace_op' + - 'workloads__for_each' + - 'xa_for_each' + - 'xa_for_each_marked' + - 'xa_for_each_range' + - 'xa_for_each_start' + - 'xas_for_each' + - 'xas_for_each_conflict' + - 'xas_for_each_marked' + - 'xbc_array_for_each_value' + - 'xbc_for_each_key_value' + - 'xbc_node_for_each_array_value' + - 'xbc_node_for_each_child' + - 'xbc_node_for_each_key_value' + - 'xbc_node_for_each_subkey' + - 'ynl_attr_for_each' + - 'ynl_attr_for_each_nested' + - 'ynl_attr_for_each_payload' + - 'zorro_for_each_dev' + - 'zpci_bus_for_each' + +IncludeBlocks: Preserve +IncludeCategories: + - Regex: '.*' + Priority: 1 +IncludeIsMainRegex: '(Test)?$' +IndentCaseLabels: false +IndentGotoLabels: false +IndentPPDirectives: None +IndentWidth: 8 +IndentWrappedFunctionNames: false +JavaScriptQuotes: Leave +JavaScriptWrapImports: true +KeepEmptyLinesAtTheStartOfBlocks: false +MacroBlockBegin: '' +MacroBlockEnd: '' +MaxEmptyLinesToKeep: 1 +NamespaceIndentation: None +ObjCBinPackProtocolList: Auto +ObjCBlockIndentWidth: 8 +ObjCSpaceAfterProperty: true +ObjCSpaceBeforeProtocolList: true + +# Taken from git's rules +PenaltyBreakAssignment: 10 +PenaltyBreakBeforeFirstCallParameter: 30 +PenaltyBreakComment: 10 +PenaltyBreakFirstLessLess: 0 +PenaltyBreakString: 10 +PenaltyExcessCharacter: 100 +PenaltyReturnTypeOnItsOwnLine: 60 + +PointerAlignment: Right +ReflowComments: false +SortIncludes: false +SortUsingDeclarations: false +SpaceAfterCStyleCast: false +SpaceAfterTemplateKeyword: true +SpaceBeforeAssignmentOperators: true +SpaceBeforeCtorInitializerColon: true +SpaceBeforeInheritanceColon: true +SpaceBeforeParens: ControlStatementsExceptForEachMacros +SpaceBeforeRangeBasedForLoopColon: true +SpaceInEmptyParentheses: false +SpacesBeforeTrailingComments: 1 +SpacesInAngles: false +SpacesInContainerLiterals: false +SpacesInCStyleCastParentheses: false +SpacesInParentheses: false +SpacesInSquareBrackets: false +Standard: Cpp03 +TabWidth: 8 +UseTab: Always +... diff --git a/hw1/section_d/.clangd b/hw1/section_d/.clangd new file mode 100644 index 0000000..e69de29 diff --git a/hw1/section_d/Makefile b/hw1/section_d/Makefile new file mode 100644 index 0000000..fc27b76 --- /dev/null +++ b/hw1/section_d/Makefile @@ -0,0 +1,12 @@ +.PHONY: all clean build zip + +obj-m += hello.o + +all: + make -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules + +clean: + make -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean + rm -rf obj + rm -rf .artifacts + rm -rf $(PROJ).zip diff --git a/hw1/section_d/dmesg.txt b/hw1/section_d/dmesg.txt new file mode 100644 index 0000000..d13334d --- /dev/null +++ b/hw1/section_d/dmesg.txt @@ -0,0 +1,6 @@ +... +[24637.358361] hello: loading out-of-tree module taints kernel. +[24637.358371] hello: module verification failed: signature and/or required key missing - tainting kernel +[24637.358647] Hello, Kernel +[24645.462203] Goodbye, Kernel +... diff --git a/hw1/section_d/hello.c b/hw1/section_d/hello.c new file mode 100644 index 0000000..a4be1f1 --- /dev/null +++ b/hw1/section_d/hello.c @@ -0,0 +1,17 @@ +#include +#include +#include + +static int __init hello_init(void) { + pr_info(KERN_INFO "Hello, Kernel"); + return 0; +} + +static void __exit hello_exit(void) { + pr_info(KERN_INFO "Goodbye, Kernel"); +} + +module_init(hello_init); +module_exit(hello_exit); +MODULE_AUTHOR("Edith Boles "); +MODULE_LICENSE("GPL");