crypt32: Implement CertDuplicateStore.
diff --git a/dlls/crypt32/crypt32.spec b/dlls/crypt32/crypt32.spec
index abeff35..7d40394 100644
--- a/dlls/crypt32/crypt32.spec
+++ b/dlls/crypt32/crypt32.spec
@@ -26,7 +26,7 @@
 @ stub CertDuplicateCRLContext
 @ stub CertDuplicateCTLContext
 @ stdcall CertDuplicateCertificateContext(ptr)
-@ stub CertDuplicateStore
+@ stdcall CertDuplicateStore(ptr)
 @ stub CertEnumCRLContextProperties
 @ stdcall CertEnumCRLsInStore(ptr ptr)
 @ stub CertEnumCTLContextProperties
diff --git a/dlls/crypt32/store.c b/dlls/crypt32/store.c
index 47e595c..b8a3d0f 100644
--- a/dlls/crypt32/store.c
+++ b/dlls/crypt32/store.c
@@ -2626,6 +2626,16 @@
     return NULL;
 }
 
+HCERTSTORE WINAPI CertDuplicateStore(HCERTSTORE hCertStore)
+{
+    WINECRYPT_CERTSTORE *hcs = (WINECRYPT_CERTSTORE *)hCertStore;
+
+    TRACE("(%p)\n", hCertStore);
+
+    if (hcs && hcs->dwMagic == WINE_CRYPTCERTSTORE_MAGIC)
+        InterlockedIncrement(&hcs->ref);
+    return hCertStore;
+}
 
 BOOL WINAPI CertCloseStore(HCERTSTORE hCertStore, DWORD dwFlags)
 {
diff --git a/include/wincrypt.h b/include/wincrypt.h
index 678f466..9784223 100644
--- a/include/wincrypt.h
+++ b/include/wincrypt.h
@@ -2605,6 +2605,8 @@
 BOOL WINAPI CertControlStore(HCERTSTORE hCertStore, DWORD dwFlags,
  DWORD dwCtrlType, void const *pvCtrlPara);
 
+HCERTSTORE WINAPI CertDuplicateStore(HCERTSTORE hCertStore);
+
 BOOL WINAPI CertCloseStore( HCERTSTORE hCertStore, DWORD dwFlags );
 
 BOOL WINAPI CertFreeCertificateContext( PCCERT_CONTEXT pCertContext );