diff --git a/.github/ISSUE_TEMPLATE/bug_report.yml b/.github/ISSUE_TEMPLATE/bug_report.yml
index 3a3dbb70e88..898fa33ec4e 100644
--- a/.github/ISSUE_TEMPLATE/bug_report.yml
+++ b/.github/ISSUE_TEMPLATE/bug_report.yml
@@ -26,7 +26,7 @@ body:
id: distro
attributes:
label: Used distribution
- description: Used distribution and it's version
+ description: Used distribution and its version
placeholder: Fedora 36
validations:
required: false
diff --git a/docs/NETWORK_ONLINE.md b/docs/NETWORK_ONLINE.md
index a8d929e4ab4..e97d8f4f309 100644
--- a/docs/NETWORK_ONLINE.md
+++ b/docs/NETWORK_ONLINE.md
@@ -152,7 +152,7 @@ For details, see the next question.
## What does "up" actually mean?
-The services that are ordered before `network-online.target` define it's
+The services that are ordered before `network-online.target` define its
meaning. *Usually* means that all configured network devices are up and have an
IP address assigned, but details may vary. In particular, configuration may
affect which interfaces are taken into account.
diff --git a/man/systemd-dissect.xml b/man/systemd-dissect.xml
index 6549aa92c85..8dd1305761b 100644
--- a/man/systemd-dissect.xml
+++ b/man/systemd-dissect.xml
@@ -149,7 +149,7 @@
a directory where an OS image was mounted.
All mounted partitions will be recursively unmounted, and the underlying loop device will be
- removed, along with all it's partition sub-devices.
+ removed, along with all its partition sub-devices.
diff --git a/src/basic/chase-symlinks.c b/src/basic/chase-symlinks.c
index 8a769e08e81..f134d369253 100644
--- a/src/basic/chase-symlinks.c
+++ b/src/basic/chase-symlinks.c
@@ -135,7 +135,7 @@ int chase_symlinks_at(
* Algorithmically this operates on two path buffers: "done" are the components of the path we
* already processed and resolved symlinks, "." and ".." of. "todo" are the components of the path we
* still need to process. On each iteration, we move one component from "todo" to "done", processing
- * it's special meaning each time. We always keep an O_PATH fd to the component we are currently
+ * its special meaning each time. We always keep an O_PATH fd to the component we are currently
* processing, thus keeping lookup races to a minimum.
*
* Suggested usage: whenever you want to canonicalize a path, use this function. Pass the absolute
diff --git a/src/core/job.c b/src/core/job.c
index 032554a0ac5..334fbf770e4 100644
--- a/src/core/job.c
+++ b/src/core/job.c
@@ -1001,7 +1001,7 @@ int job_finish_and_invalidate(Job *j, JobResult result, bool recursive, bool alr
}
/* A special check to make sure we take down anything RequisiteOf= if we aren't active. This is when
- * the verify-active job merges with a satisfying job type, and then loses it's invalidation effect,
+ * the verify-active job merges with a satisfying job type, and then loses its invalidation effect,
* as the result there is JOB_DONE for the start job we merged into, while we should be failing the
* depending job if the said unit isn't in fact active. Oneshots are an example of this, where going
* directly from activating to inactive is success.
diff --git a/src/core/unit.c b/src/core/unit.c
index a67dceb31fa..f5544cbd924 100644
--- a/src/core/unit.c
+++ b/src/core/unit.c
@@ -905,7 +905,7 @@ static int unit_reserve_dependencies(Unit *u, Unit *other) {
/* Let's reserve some space in the dependency hashmaps so that later on merging the units cannot
* fail.
*
- * First make some room in the per dependency type hashmaps. Using the summed size of both unit's
+ * First make some room in the per dependency type hashmaps. Using the summed size of both units'
* hashmaps is an estimate that is likely too high since they probably use some of the same
* types. But it's never too low, and that's all we need. */
diff --git a/src/home/homed-manager.c b/src/home/homed-manager.c
index 76b038caddb..84b5618671c 100644
--- a/src/home/homed-manager.c
+++ b/src/home/homed-manager.c
@@ -1626,7 +1626,7 @@ void manager_revalidate_image(Manager *m, Home *h) {
assert(h);
/* Frees an automatically discovered image, if it's synthetic and its image disappeared. Unmounts any
- * image if it's mounted but it's image vanished. */
+ * image if it's mounted but its image vanished. */
if (h->current_operation || !ordered_set_isempty(h->pending_operations))
return;
diff --git a/src/shared/bus-unit-util.c b/src/shared/bus-unit-util.c
index badd61656c6..6966cfd8389 100644
--- a/src/shared/bus-unit-util.c
+++ b/src/shared/bus-unit-util.c
@@ -2757,7 +2757,7 @@ int unit_load_state(sd_bus *bus, const char *name, char **load_state) {
if (!path)
return log_oom();
- /* This function warns on it's own, because otherwise it'd be awkward to pass
+ /* This function warns on its own, because otherwise it'd be awkward to pass
* the dbus error message around. */
r = sd_bus_get_property_string(
diff --git a/units/systemd-time-wait-sync.service.in b/units/systemd-time-wait-sync.service.in
index 8ef3db0d5df..d14491a01e5 100644
--- a/units/systemd-time-wait-sync.service.in
+++ b/units/systemd-time-wait-sync.service.in
@@ -11,7 +11,7 @@
Description=Wait Until Kernel Time Synchronized
Documentation=man:systemd-time-wait-sync.service(8)
-# Note that this tool doesn't need CAP_SYS_TIME itself, but it's primary
+# Note that this tool doesn't need CAP_SYS_TIME itself, but its primary
# usecase is to run in conjunction with a local NTP service such as
# systemd-timesyncd.service, which is conditioned this way. There might be
# niche usecases where running this service independently is desired, but let's