]> git.kernelconcepts.de Git - karo-tx-linux.git/blobdiff - net/sctp/transport.c
net, sctp: convert sctp_transport.refcnt from atomic_t to refcount_t
[karo-tx-linux.git] / net / sctp / transport.c
index 7cdd6bcddbc5ad277f525635cf56788f70a4ee30..80a97c8501a77be978a01ae9ec769f4c365bc14f 100644 (file)
@@ -99,7 +99,7 @@ static struct sctp_transport *sctp_transport_init(struct net *net,
        /* Initialize the 64-bit random nonce sent with heartbeat. */
        get_random_bytes(&peer->hb_nonce, sizeof(peer->hb_nonce));
 
-       atomic_set(&peer->refcnt, 1);
+       refcount_set(&peer->refcnt, 1);
 
        return peer;
 }
@@ -172,7 +172,7 @@ static void sctp_transport_destroy_rcu(struct rcu_head *head)
  */
 static void sctp_transport_destroy(struct sctp_transport *transport)
 {
-       if (unlikely(atomic_read(&transport->refcnt))) {
+       if (unlikely(refcount_read(&transport->refcnt))) {
                WARN(1, "Attempt to destroy undead transport %p!\n", transport);
                return;
        }
@@ -311,7 +311,7 @@ void sctp_transport_route(struct sctp_transport *transport,
 /* Hold a reference to a transport.  */
 int sctp_transport_hold(struct sctp_transport *transport)
 {
-       return atomic_add_unless(&transport->refcnt, 1, 0);
+       return refcount_inc_not_zero(&transport->refcnt);
 }
 
 /* Release a reference to a transport and clean up
@@ -319,7 +319,7 @@ int sctp_transport_hold(struct sctp_transport *transport)
  */
 void sctp_transport_put(struct sctp_transport *transport)
 {
-       if (atomic_dec_and_test(&transport->refcnt))
+       if (refcount_dec_and_test(&transport->refcnt))
                sctp_transport_destroy(transport);
 }