diff --git a/lib/geocoder/orms/active_record.rb b/lib/geocoder/orms/active_record.rb
index b1bac032aa8a6b9d53c64635c6722c6bcfba624e..90e54067b1c5b7e17367ef880f10dbee25ef795f 100644
--- a/lib/geocoder/orms/active_record.rb
+++ b/lib/geocoder/orms/active_record.rb
@@ -149,11 +149,11 @@ module Geocoder::Orm
     # coordinates as an array: <tt>[lat, lon]</tt>.
     #
     def fetch_coordinates(save = false)
-      geocode do |r|
+      geocode do |o,r|
         unless r.latitude.nil? or r.longitude.nil?
           method = (save ? "update" : "write") + "_attribute"
-          send method, self.class.geocoder_options[:latitude],  r.latitude
-          send method, self.class.geocoder_options[:longitude], r.longitude
+          o.send method, self.class.geocoder_options[:latitude],  r.latitude
+          o.send method, self.class.geocoder_options[:longitude], r.longitude
         end
         r.coordinates
       end
@@ -171,10 +171,10 @@ module Geocoder::Orm
     # address as a string.
     #
     def fetch_address(save = false)
-      geocode do |r|
+      geocode do |o,r|
         unless r.address.nil?
           method = (save ? "update" : "write") + "_attribute"
-          send method, self.class.geocoder_options[:fetched_address], r.address
+          o.send method, self.class.geocoder_options[:fetched_address], r.address
         end
         r.address
       end
diff --git a/lib/geocoder/orms/base.rb b/lib/geocoder/orms/base.rb
index 1edf7e458b057dec41064803869b04815eb61d96..dedeefe4cc97f8df39fa2d0147e93761feaaeed3 100644
--- a/lib/geocoder/orms/base.rb
+++ b/lib/geocoder/orms/base.rb
@@ -52,9 +52,9 @@ module Geocoder
         # passing a block to this method overrides the one given in the model
         if result = Geocoder.search(*args).first
           if block_given?
-            yield(result)
+            yield(self, result)
           else
-            self.class.geocoder_options[:block].call(result)
+            self.class.geocoder_options[:block].call(self, result)
           end
         end
       end