// MADE BY QT666
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<cstring>
#include<map>
#include<vector>
#define RG register
#define int long long
using namespace std;
typedef long long ll;
const int N=3000050;
const int rhl=1000000009;
vector<int> Map[30000],id[30000];
int R,C,n;
int heng[N],down[N],up[N],tt,sum[200000];
ll ans,inv[10],tr[50050][5],T=40000,xu=10000,q[N],res;
inline void pre(int g){
memset(sum,0,sizeof(sum));
for(RG int i=1;i<=C;i++) sum[i]=sum[i-1]+Map[g][i];
}
inline int query_left(int i){
RG int l=1,r=i,ret=i;
while(l<=r){
int mid=(l+r)>>1;
if(sum[i]-sum[mid-1]==(i-mid+1)) r=mid-1,ret=mid;
else l=mid+1;
}
return i-ret;
}
inline int query_right(int i){
RG int l=i,r=C,ret=i;
while(l<=r){
int mid=(l+r)>>1;
if(sum[mid]-sum[i-1]==(mid-i+1)) ret=mid,l=mid+1;
else r=mid-1;
}
return ret-i;
}
inline void work_heng(int g){
for(int i=1;i<=C;i++){
if(Map[g][i]){
int l1=query_left(i),l2=query_right(i);
heng[id[g][i]]=min(l1,l2);
}
}
}
inline void work_down(int g){
for(RG int i=R-1;i>=1;i--){
if(Map[i][g]){
if(Map[i+1][g]) down[id[i][g]]=down[id[i+1][g]]+1;
}
}
}
inline void work_up(int g){
for(RG int i=2;i<=R;i++){
if(Map[i][g]){
if(Map[i-1][g]) up[id[i][g]]=up[id[i-1][g]]+1;
}
}
}
inline int calc(ll sx,ll mx){return (sx+mx)*(mx-sx+1)%rhl*inv[2]%rhl;}
inline ll qpow(ll a,ll b){ll ans=1; while (b){ if (b&1) (ans*=a)%=rhl; (a*=a)%=rhl,b>>=1; } return ans; }
inline void update(int x,int val,int type){
x+=xu;
for(int i=x;i<=T;i+=i&-i) tr[i][type]+=val;
}
inline int query(int x,int type){
int ret=0;x+=xu;
for(int i=x;i;i-=i&-i) ret+=tr[i][type];
return ret;
}
inline void work(int i,int g,int top,int type){
int L=heng[id[i-1][g]];
update(L,(i-1-top)*type,1);
update(L,L*(i-1-top)*type,2);
update(L,L*L*(i-1-top)*type,3);
update(L,calc(1,L-1)*(i-1-top)*type,4);
}
inline void solve(int g){
int top=1,la=1+down[id[1][g]];
while(1){
if(la>R) break;
for(int i=top;i<=la;i++){
ll l=heng[id[i][g]],x=down[id[i][g]];
(ans+=(query(C,1)-query(l,1))%rhl*calc(1,l-1)*x%rhl)%=rhl;
ans+=(l*query(l,2)-query(l,3)+query(l,4))*x;
if(i>top){
q[++res]=i;work(i,g,top,1);
}
}
for(int i=1;i<=res;i++) work(q[i],g,top,-1);
top=la+1;res=0;
while(top<=R&&Map[top][g]==0) top++;
la=top+down[id[top][g]];
}
}
main(){
scanf("%lld%lld%lld",&R,&C,&n);
inv[2]=qpow(2,rhl-2);
for(RG int i=1;i<=R;i++) Map[i].push_back(0),id[i].push_back(0);
for(RG int i=1;i<=R;i++)
for(RG int j=1;j<=C;j++)
++tt,Map[i].push_back(1),id[i].push_back(tt);
for(int i=1;i<=C;i++) Map[R+1].push_back(0),id[R+1].push_back(0);
for(RG int i=1;i<=n;i++){
int x,y;scanf("%lld%lld",&x,&y);Map[x][y]=0;
}
for(RG int i=1;i<=R;i++) pre(i),work_heng(i);
for(RG int i=1;i<=C;i++) work_down(i);
for(RG int i=1;i<=C;i++) work_up(i);
for(RG int i=1;i<=C;i++) solve(i);
printf("%lld\n",ans);
return 0;
}