diff --git a/docs/book/src/SUMMARY.md b/docs/book/src/SUMMARY.md
index eaed330a68ff..b6cb78a79420 100644
--- a/docs/book/src/SUMMARY.md
+++ b/docs/book/src/SUMMARY.md
@@ -108,3 +108,4 @@
- [Code Review in Cluster API](./REVIEWING.md)
- [Version Support](./reference/versions.md)
- [Roadmap](./roadmap.md)
+ - [Supported Labels and Annotations](./reference/labels_and_annotations.md)
diff --git a/docs/book/src/reference/api_reference.md b/docs/book/src/reference/api_reference.md
index 536b528e27ee..8d2f81417247 100644
--- a/docs/book/src/reference/api_reference.md
+++ b/docs/book/src/reference/api_reference.md
@@ -5,3 +5,5 @@ Cluster API currently exposes the following APIs:
* the Cluster API Custom Resource Definitions (CRDs): [documentation](https://doc.crds.dev/github.com/kubernetes-sigs/cluster-api)
* Golang APIs: [godoc](https://pkg.go.dev/sigs.k8s.io/cluster-api)
+
+* Supported Labels and Annotations: [documentation](./labels_and_annotations.md)
\ No newline at end of file
diff --git a/docs/book/src/reference/labels_and_annotations.md b/docs/book/src/reference/labels_and_annotations.md
new file mode 100644
index 000000000000..0f8fb3ef6b1b
--- /dev/null
+++ b/docs/book/src/reference/labels_and_annotations.md
@@ -0,0 +1,47 @@
+**Supported Labels:**
+
+
+|label |note |
+|:--------:|:--------:|
+| cluster.x-k8s.io/cluster-name| It is set on machines linked to a cluster and external objects(bootstrap and infrastructure providers) |
+| topology.cluster.x-k8s.io/owned| It is set on all the object which are managed as part of a ClusterTopology. |
+|topology.cluster.x-k8s.io/deployment-name | It is set on the generated MachineDeployment objects to track the name of the MachineDeployment topology it represents. |
+| cluster.x-k8s.io/provider| It is set on components in the provider manifest. This label allows to easily identify all the components belonging to a provider. The clusterctl tool uses this label for implementing provider's lifecycle operations. |
+| cluster.x-k8s.io/watch-filter | It can be applied to any Cluster API object. Controllers which allow for selective reconciliation may check this label and proceedwith reconciliation of the object only if this label and a configured value is present. |
+| cluster.x-k8s.io/interruptible|It is used to mark the nodes that run on interruptible instances. |
+|cluster.x-k8s.io/control-plane | It is set on machines or related objects that are part of a control plane. |
+| cluster.x-k8s.io/set-name| It is set on machines if they're controlled by MachineSet. |
+| cluster.x-k8s.io/deployment-name| It is set on machines if they're controlled by a MachineDeployment. |
+| machine-template-hash| It is applied to Machines in a MachineDeployment containing the hash of the template. |
+
+
+
+**Supported Annotations:**
+
+|annotation | note |
+|:--------:|:--------:|
+| topology.cluster.x-k8s.io/managed-field-paths | It is used to store the list of paths managed by the topology controller. Changes to those paths will be considered authoritative.
NOTE: Managed field depends on the last reconciliation of a managed object; this list can change during the lifecycle of an object, depending on how the corresponding template + patch/variable changes over time.
NOTE: The topology controller is only concerned about managed paths in the spec, given that we are dropping spec. From the result to reduce verbosity of the generated annotation.
NOTE: Managed paths are relevant only for unstructured objects where it is not possible to easily discover which fields have been set by templates + patches/variables at a given reconcile. Instead, it is not necessary to store managed paths for typed objets (e.g. Cluster, MachineDeployments) given that the topology controller explicitly sets a well-known, immutable list of fields at every reconcile.
Deprecated: Topology controller is now using server side apply and this annotation will be removed in a future release. |
+| unsafe.topology.cluster.x-k8s.io/disable-update-class-name-check | It can be used to disable the webhook check on update that disallows a pre-existing Cluster to be populated with Topology information and Class. |
+| cluster.x-k8s.io/cluster-name | It is set on nodes identifying the name of the cluster the node belongs to. |
+|cluster.x-k8s.io/cluster-namespace | It is set on nodes identifying the namespace of the cluster the node belongs to |
+| cluster.x-k8s.io/machine | It is set on nodes identifying the machine the node belongs to |
+| cluster.x-k8s.io/owner-kind | It is set on nodes identifying the owner kind |
+| cluster.x-k8s.io/owner-name | It is set on nodes identifying the owner name |
+| cluster.x-k8s.io/paused | It can be applied to any Cluster API object to prevent a controller from processing a resource. Controllers working with Cluster API objects must check the existence of this annotationon the reconciled object. |
+| cluster.x-k8s.io/disable-machine-create | It can be used to signal a MachineSet to stop creating new machines. It is utilized in the OnDelete MachineDeploymentStrategy to allow the MachineDeployment controller to scale down older MachineSets when Machines are deleted and add the new replicas to the latest MachineSet. |
+| cluster.x-k8s.io/delete-machine | It marks control plane and worker nodes that will be given priority for deletion when KCP or a machineset scales down. It is given top priority on all delete policies. |
+| cluster.x-k8s.io/cloned-from-name | It is the infrastructure machine annotation that stores the name of the infrastructure template resource that was cloned for the machine. This annotation is set only during cloning a template. Older/adopted machines will not have this annotation. |
+| cluster.x-k8s.io/cloned-from-groupkind | It is the infrastructure machine annotation that stores the group-kind of the infrastructure template resource that was cloned for the machine. This annotation is set only during cloning a template. Older/adopted machines will not have this annotation. |
+| cluster.x-k8s.io/skip-remediation | It is used to mark the machines that should not be considered for remediation by MachineHealthCheck reconciler. |
+| cluster.x-k8s.io/managed-by | It can be applied to InfraCluster resources to signify that some external system is managing the cluster infrastructure. Provider InfraCluster controllers will ignore resources with this annotation. An external controller must fulfill the contract of the InfraCluster resource. External infrastructure providers should ensure that the annotation, once set, cannot be removed. |
+| topology.cluster.x-k8s.io/dry-run | It is an annotation that gets set on objects by the topology controller only during a server side dry run apply operation. It is used for validating update webhooks for objects which get updated by template rotation (e.g. InfrastructureMachineTemplate). When the annotation is set and the admission request is a dry run, the webhook should deny validation due to immutability. By that the request will succeed (without any changes to the actual object because it is a dry run) and the topology controller will receive the resulting object. |
+| machine.cluster.x-k8s.io/exclude-node-draining | It explicitly skips node draining if set |
+| pre-drain.delete.hook.machine.cluster.x-k8s.io | It specifies the prefix we search each annotation for during the pre-drain.delete lifecycle hook to pause reconciliation of deletion. These hooks will prevent removal of draining the associated node until all are removed. |
+| pre-terminate.delete.hook.machine.cluster.x-k8s.io | It specifies the prefix we search each annotation for during the pre-terminate.delete lifecycle hook to pause reconciliation of deletion. These hooks will prevent removal of an instance from an infrastructure provider until all are removed. |
+| machinedeployment.clusters.x-k8s.io/revision | It is the revision annotation of a machine deployment's machine sets which records its rollout sequence. |
+| machinedeployment.clusters.x-k8s.io/revision-history | It maintains the history of all old revisions that a machine set has served for a machine deployment. |
+| machinedeployment.clusters.x-k8s.io/desired-replicas | It is the desired replicas for a machine deployment recorded as an annotation in its machine sets. Helps in separating scaling events from the rollout process and for determining if the new machine set for a deployment is really saturated. |
+| machinedeployment.clusters.x-k8s.io/max-replicas | It is the maximum replicas a deployment can have at a given point, which is machinedeployment.spec.replicas + maxSurge. Used by the underlying machine sets to estimate their proportions in case the deployment has surge replicas. |
+| controlplane.cluster.x-k8s.io/skip-coredns | It explicitly skips reconciling CoreDNS if set. |
+|controlplane.cluster.x-k8s.io/skip-kube-proxy | It explicitly skips reconciling kube-proxy if set.|
+| controlplane.cluster.x-k8s.io/kubeadm-cluster-configuration| It is a machine annotation that stores the json-marshalled string of KCP ClusterConfiguration. This annotation is used to detect any changes in ClusterConfiguration and trigger machine rollout in KCP.|
\ No newline at end of file