#include<iostream>
using namespace std;
int dx[3]={-1,1,0};
int dy[3]={0,0,1};
int n,m,tu[305][305];
int maxx=0,sum=0;
int vis[305][305];
void dfs(int x,int y){
if(xn&&ym){
maxx=max(sum,maxx);
sum=0;
return;
}
for(int i=0;i<3;i++){
int xx=dx[i]+x;
int yy=dy[i]+y;
if(xx>0&&yy>0&&xx<=n&&yy<=m&&!vis[xx][yy]){
vis[xx][yy]=1;
sum+=tu[xx][yy];
dfs(xx,yy);
vis[xx][yy]=0;
}
}
}
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>tu[i][j];
}
}
vis[1][1]=1;
dfs(1,1);
cout<<maxx;
return 0;
}